python基础操作练习题

发布时间 2023-10-04 13:01:46作者: feixianxing

使用版本:python 3.6.8

IDE:pycharm

前言

这些练习题是在神经网络与深度学习课程上老师提供的,原因是有些同学没学过python,作为简单的练手习题。

题目都很简单,加上python本身也比较简单,有些题目的作答可以一行代码实现(虽然可读性就下降了)。

练习题

2.1 数位之和

编写程序,输入一个正整数,然后输出各位数字之和。
例如,输入字符串1234,输出10。

from functools import reduce
from operator import add

print(reduce(add, map(int, list(input()))))

2.2 字符串翻转

编写程序,输入一个字符串,输出翻转(首尾交换)后的字符串,要求使用内置函数实现。
例如,输入字符串12345,输出54321。

print(''.join(reversed(input())))

2.3 最大值

编写程序,输入一个包含若干整数的列表,输出列表中的最大值。
例如,输入[1, 2, 3, 4, 5, 888],输出888。

print(max(eval(input())))

2.4 类型转换——整数转字符串

编写程序,输入一个包含若干整数的列表,把列表中所有整数转换为字符串,然后输出包含这些字符串的列表。
例如,输入[1, 2, 3, 4, 5, 888],输出['1', '2', '3', '4', '5', '888']

print(list(map(str, eval(input()))))

2.5 filter

编写程序,输入一个包含若干任意数据的列表,输出该列表中等价于True的元素组成的列表。
例如,输入[1, 2, 0, None, False, 'a'],输出[1, 2, 'a']。

print(list(filter(None, eval(input()))))

2.6 指定key排序

编写程序,输入一个包含若干整数的列表,输出一个新列表,新列表中奇数在前偶数在后,并且奇数之间的相对顺序不变,偶数之间的相对顺序也不变。

nums = eval(input())
print(sorted(nums, key=(lambda x: x%2), reverse=True))

3.1 列表推导式与列表求和

阿凡提与国王比赛下棋,国王说要是自己输了的话阿凡提想要什么他都可以拿得出来。阿凡提说那就要点米吧,棋盘一共64个小格子,在第一个格子里放1粒米,第二个格子里放2粒米,第三个格子里放4粒米,第四个格子里放8粒米,以此类推,后面每个格子里的米都是前一个格子里的2倍,一直把64个格子都放满。编写程序,生成一个列表,其中元素为每个棋盘格子里米的粒数,并输出这些数字的和,也就是一共需要多少粒米。
要求使用列表推导式。

from functools import reduce
from operator import add
print(reduce(add, [2**x for x in range(64)]))

3.2 列表推导式if筛选

编写程序,输入一个包含若干整数的列表,输出由其中的奇数组成的新列表。
例如,输入[1,2,3,4,5,6,7,8],输出[1, 3, 5, 7]。
要求使用列表推导式。

data = eval(input())
print([x for x in data if x%2==1])

3.3 向量内积

编写程序,输入两个包含若干整数的等长列表表示两个向量,输出这两个向量的内积。
例如,输入[1,2,3]和[4,5,6],内积计算方法为1*4 + 2*5 + 3*6 = 32,输出32。
要求使用列表推导式。

from functools import reduce
from operator import add

x1 = eval(input())
x2 = eval(input())

print(reduce(add, [a*b for (a, b) in zip(x1, x2)]))

3.4 找最大值与其下标

编写程序,输入一个包含若干整数的列表,输出其中的最大值,以及所有最大值的下标组成的列表。
例如,输入[1,2,3,1,2,3,3],输出3和[2, 5, 6]。
要求使用列表推导式。

data = eval(input())
max_num = max(data)
print(max_num, [idx for idx in range(len(data)) if data[idx]==max_num])

3.5 生成随机序列与计数

编写程序,首先生成包含1000个随机数字字符的字符串,然后统计每个数字的出现次数。

from random import choices
import string
s = ''.join(choices(string.digits, k=1000))
print(s)
cnt = {}
for x in s:
    cnt[x] = cnt.get(x, 0) + 1

print(cnt)

3.6 字符串去重(保持顺序)

编写程序,输入一个字符串,输出其中唯一字符组成的新字符串,要求新字符串中的
字符顺序与其在原字符串中的相对顺序一样。
例如,输入'1122a3344',输出'12a34'。

s = input()
ss = list(set(s))
ss.sort(key=s.index)
print(''.join(ss))

3.7 集合运算

编写程序,输入两个集合A和B,输出它们的并集、交集、对称差集以及差集A-B和B-A。
要求使用集合运算符。

A = set(eval(input()))
B = set(eval(input()))

print(A | B)
print(A & B)
print(A ^ B)
print(A - B)
print(B - A)

3.8 空格去重

编写程序,输入一个字符串,删除其中的重复空格,也就是如果有连续的多个空格的话就只保留一个,然后输出处理后的字符串。

s = input()
print(''.join([s[idx] for idx in range(len(s)) if idx==0 or s[idx]!=' ' or s[idx-1]!=' ']))

3.9 元音字母大写

编写程序,输入一个字符串,把其中的元音字母i、o、a、e和u替换成对应的大写字母,然后输出新字符串。

vowel = ('a', 'e', 'i', 'o', 'u')

s = input()
print(''.join(list(map(
    (lambda x: x.upper() if x in vowel else x),
    s
))))

3.10 检查列表是否存在相同整数

编写程序,测试列表中的若干整数之间是否有重复。

data = eval(input())
print("没有重复") if len(data) == len(list(set(data))) else print("存在重复")

4.7 递归实现数位求和

使用递归法计算自然数各位数字之和。

def sum_by_digit(num):
    return num%10 + sum_by_digit(num//10) if num > 10 else num

test_data = (1234, 6789, 6379)

for test in test_data:
    print(f"{test} --> {sum_by_digit(test)}")

4.8 猜数游戏

通过参数可以指定一个整数范围和猜测的最大次数,系统在指定范围内随机产生一个整数,然后让用户猜测该数的值,系统根据玩家的猜测进行提示(例如,猜大了,猜小了,猜对了),玩家则可以根据系统的提示对下一次的猜测进行适当调整,直到猜对或次数用完。

from random import choice

config = {
    'max_num': 1000,
    'min_num': 0,
    'max_guess_times': 20
}

answer = choice(range(config['min_num'], config['max_num']+1))

guess_times = 0
while guess_times < config['max_guess_times']:

    print(f"猜数游戏,请输入一个数字,\n范围是[{config['min_num']}, {config['max_num']}]: ") \
        if guess_times == 0 else print("再猜一次: ")
    guess = int(input())
    guess_times += 1
    if guess == answer:
        print("猜对了!")
        break
    elif guess > answer:
        print("猜大了")
    else:
        print("猜小了")

if guess_times >= config['max_guess_times']:
    print("--- 机会用完了 ---")