第1关:字符串去重排序
任务描述
输入一个非空字符串,去除重复的字符后,从小到大排序输出为一个新字符串。
输入格式
一个非空字符串
输出格式
去重排序后的字符串
示例
- 输入:
Life is short, you need Python!
- 输出:
!,LPdefhinorstuy
参考代码
print(''.join(sorted(set(input()))))
第2关:列表去重
任务描述
输入一系列以逗号分隔的英文人名,其中包含重复的名字,请将其中重复的名字去掉,输出包含不重复人名的列表,名字出现顺序与输入顺序相同。
输入格式
一系列以逗号分隔的英文人名
输出格式
包含不重复人名的列表,名字出现顺序与输入顺序相同
示例 1
- 输入:
Calvin,bob,ada,McCord,Smith,Babbs,Calvin,Smith
- 输出:
['Calvin', 'bob', 'ada', 'McCord', 'Smith', 'Babbs']
参考代码
res = []
names = input().split(',')
for name in names:if name not in res:res.append(name)
print(res)
第3关:猜年龄
任务描述
美国数学家维纳(N.Wiener)智力早熟,11岁就上了大学。他曾在1935~1936年应邀来中国清华大学讲学。一次,他参加某个重要会议,年轻的脸孔引人注目。于是有人询问他的年龄,他回答说:“我年龄的立方是个4位数。我年龄的4次方是个6位数。这10个数字正好包含了从0到9这10个数字,每个都恰好出现1次。” 请编程输出当年维纳的年龄。
输入格式
该题目没有输入
输出格式
一个正整数(维纳当年的年龄)
示例
- 输出:
9
参考代码
age1 = age2 = 0
while age1**3 < 10000:age1 += 1
while True:b = age2**4if b >= 100000 and b < 1000000:breakage2 += 1for i in range(age2, age1):num1 = i**3num2 = i**4res = set(str(num1)+str(num2))if len(res) == 10:print(i)
第4关:集合的属性、方法与运算
任务描述
将用户输入用空格分隔的一系列地名创建集合MySet,输入一个正整数 n,你将被要求读入 n 个输入(输入形式如下所示),每得到一个输入后,根据输入进行操作。
add name: # 在集合中加入元素name
print: # 将集合转为列表,按元素升序排序后输出列表
del name: # 删除集合中的元素name,当name不存在时,不能引发错误
update name: # name为空格逗号分隔的字符串,将其转为集合,并用name中的元素修改集合MySet
clear: # 清空集合
输入格式
第一行输入一个正整数 n
输出格式
每遇到“print”时,将集合转为列表,按元素升序排序后输出列表
示例
- 输入:
8
湖北 湖南 吉林
print
del 湖北
print
clear
add 江西
add 河北
update 北京 上海 天津 重庆
print
- 输出:
['吉林', '湖北', '湖南']
['吉林', '湖南']
['上海', '北京', '天津', '江西', '河北', '重庆']
参考代码
n = int(input())
name = input()
Set = set(name.split())
for i in range(n):List = input().split() if List[0] == 'print':print(sorted(list(Set)))elif List[0] == 'update': Set.update(set(List[1:]))elif List[0] == 'add': Set.add(List[1])elif List[0] == 'del': Set.discard(List[1])elif List[0] == 'clear':Set.clear()
第5关:集合介绍
任务描述
集合是一个无序的、没有重复元素的数据类型,在输出或转为序列类型时,其元素位置随机出现。
例如:
print(set())
# 产生空集合 set()
print(set('Hello Python'))
# 字符串转集合,去掉重复字符 {'t', 'h', 'P', 'H', 'l', 'e', 'y', 'o', ' ', 'n'}
print(set((1, 2, 3, 4, 5, 5)))
# 元组转集合,去掉重复元素 {1, 2, 3, 4, 5}
print(set(set(['H', 'e', 'l', 'l', 'o', ' ', 'P', 'y', 't', 'h', 'o', 'n'])))
# 列表转集合,去掉重复元素{'t', 'h', 'P', 'H', 'l', 'e', 'y', 'o', ' ', 'n'}
print(set([1, 2, 1, 2, 3, 4, 5, 6, 0, 9, 12, 22, 3]))
# 列表转集合,去掉重复元素 {0, 1, 2, 3, 4, 5, 6, 9, 12, 22}
print(set({'University': 'WHUTI', 'Rank': 40}))
# 字典转集合,返回字典的键(字典的键唯一),不确定顺序 {'Rank', 'University'}
print(set(enumerate(['H', 'e', 'l', 'l', 'o', ' ', 'P', 'y', 't', 'h', 'o', 'n'])))
# {(8, 't'), (2, 'l'), (7, 'y'), (3, 'l'), (4, 'o'), (5, ' '), (6, 'P'), (9, 'h'), (11, 'n'), (0, 'H'), (1, 'e'), (10, 'o')}
李白是一个社区大学的老师,一天,他让学生小明计算一下温室里植物的平均高度。
平均高度 = 不同高度的和 / 不同高度的数量
输入格式
输入N
个用空格分隔的植物的高度
输出格式
在一行内输出植物的平均高度,保留小数点后3位
示例
- 输入:
161
182
161
154
176
170
167
171
170
174
- 输出:
169.375
参考代码
def average(array):Set = set(array)return sum(Set)/len(Set)if __name__ == '__main__':arr = list(map(int, input().split()))result = average(arr)print(result)
第6关:手机销售统计
任务描述
sale2018.csv
sale2019.csv
文件中包含有2018和2019手机销售榜单数据(市场份额百分数),请根据要求升序输出分析结果:
1.输入’1’时,以列表形式在两行中分别输出2019年和2018年上榜品牌
2.输入’2’时,以列表形式输出2019年和2018年都上榜的品牌
3.输入’3’时,以列表形式输出2019年和2018年上榜的所有品牌
4.输入’4’时,以列表形式输出2019年新上榜品牌
5.输入’5’时,以列表形式输出2019年新上榜和落榜品牌
读取文件可参考代码:
with open('sale2019.csv', 'r', encoding='utf-8') as data2019: sale2019 = [[line.strip().split(',')[0], float(line.strip().split(',')[1])] for line in data2019]
示例
- 输入:
5
- 输出:
['中兴', '联想', '金立']
参考代码
with open('/data/bigfiles/sale2019.csv', 'r', encoding='utf-8') as data2019: sale2019 = set([line.strip().split(',')[0] for line in data2019])
with open('/data/bigfiles/sale2018.csv', 'r', encoding='utf-8') as data2018: sale2018 = set([line.strip().split(',')[0] for line in data2018])n = input()
if n =='1':print(sorted(sale2019))print(sorted(sale2018))
elif n =='2':print(sorted(sale2018&sale2019))
elif n =='3':print(sorted(sale2018|sale2019))
elif n =='4':print(sorted(sale2019-sale2018))
elif n =='5':print(sorted((sale2019-sale2018)|(sale2018-sale2019)))
第7关:集合添加元素
任务描述
向集合中加入单一元素,可以使用.add() 方法操作,该 操作将向集合中加入,返回值为“None”
例如:
s = set('Wuhan')
print(s) # {'n', 'a', 'W', 'u', 'h'}
s.add('A') # 向集合中增加一个元素
print(s) # {'n', 'a', 'A', 'W', 'u', 'h'}
print(s.add('Hubei')) # 本方法返回值为 None
print(s) # {'n', 'a', 'A', 'W', 'u', 'Hubei', 'h'}
应用你的知识帮助你的好朋友小明,小明喜欢集邮,他有大量的来自不同国家的邮票,他决定数一下他的集邮册中共有来自多少个不同国家的邮票,他请你帮忙,你一个一个的把N张邮票拿出来,找出共有多少个不重复的国家。
输入格式
第一行输入一个整数N,表示所有邮票的数目
接下来的N行,每行输入一张邮票来自哪一个国家的名字
输出格式
在一行中输出不重复的国家的数量
示例
- 输入:
7
UK
China
USA
France
New Zealand
UK
France
- 输出:
5
参考代码
n = int(input())
Set = set()
for i in range(n):Set.add(input())
print(len(Set))
第8关:列表嵌套字典的排序
任务描述
第一行输入一个正整数 N,随后的N 行各输入一个人的姓名和年龄,中间用空格分隔(形如 “Tom 18” ),将字符串转为形如 {“name”:“Tom”,“age”:18} 的字典,按顺序加入到列表中,得到一个元素为字典的列表,分别根据年龄和姓名对其排序输出。
输入格式
第一行输入一个正整数 N
随后的N 行各输入一个形如 “Tom 18” 的字符串
成绩 | 等级 | 绩点 |
---|---|---|
90-100 | A | 4.0 |
85-89 | A- | 3.7 |
82-84 | B+ | 3.3 |
78-81 | B | 3.0 |
75-77 | B- | 2.7 |
72-74 | C+ | 2.3 |
68-71 | C | 2.0 |
64-67 | C- | 1.5 |
60-63 | D | 1.3 |
补考60 | D- | 1.0 |
60以下 | F | 0 |
输出格式
根据年龄排序的列表
根据姓名排序的列表
示例 1
- 输入:
4
Tom 18
Jerry 47
Cat 20
Doge 33
- 输出:
[{'name': 'Tom', 'age': 18}, {'name': 'Cat', 'age': 20}, {'name': 'Doge', 'age': 33}, {'name': 'Jerry', 'age': 47}]
[{'name': 'Cat', 'age': 20}, {'name': 'Doge', 'age': 33}, {'name': 'Jerry', 'age': 47}, {'name': 'Tom', 'age': 18}]
参考代码
n = int(input())
res = []
for i in range(n):data = input().split()res.append({'name':data[0], 'age':int(data[1])})
print(sorted(res, key = lambda x:x['age']))
print(sorted(res, key = lambda x:x['name']))
第9关:绩点计算
任务描述
平均绩点计算方法:
(课程学分1*绩点+课程学分2*绩点+......+课程学分n*绩点)/(课程学分1+课程学分2+......+课程学分n)
用户循环输入五分制成绩和课程学分,题目测试数据保证至少有一组或以上合法数据输入。输入‘-1’时结束输入,计算学生平均绩点。等级与绩点对应关系如下表:
输入格式
每组输入包括两行
第一行是五分制的分数
第二行是一个代表学分的数字
输出格式
平均绩点,严格保留两位小数
示例
- 输入:
A
3
B
3
A
2
-1
- 输出:
3.62
参考代码
dic = {'A':4.0, 'A-':3.7, 'B+':3.3, 'B':3.0, 'B-':2.7, 'C+':2.3, 'C':2.0, 'C-':1.5, 'D':1.3, 'D-':1.0, 'F':0}
score = num = 0
while 1:n = input()if n != '-1':sco = int(input())score = score + dic[n]*sconum = num + scoelse:print(f'{score/num:.2f}')break
第10关:通讯录(MOD)
任务描述
模拟通讯录的数据修改功能。
def menu():print('''\n欢迎使用PYTHON学生通讯录
1:添加学生
2:删除学生
3:修改学生信息
4:搜索学生
5:显示全部学生信息
6:退出并保存''')
dic={'张自强': ['12652141777', '材料'], '庚同硕': ['14388240417', '自动化'], '王岩': ['11277291473', '文法']}
要求编写程序
输出字典原始数据,再调用menu函数输出用户选择界面
(1)输入‘3’ 进行修改学生信息,输入姓名,如果该姓名已存在,则继续输入电话,学院信息,并输出“Success”的提示信息,如果不存在,给出“No Record”提示信息。
无论是否修改成功,结束后需要输出操作后的字典数据。
(2)如果输入其他选项,无需读入姓名,直接输出“ERROR”。
输入格式
3 庚同硕 123456789 法学
输出格式
{‘张自强’: [‘12652141777’, ‘材料’], ‘庚同硕’: [‘14388240417’, ‘自动化’], ‘王岩’: [‘11277291473’, ‘文法’]}
欢迎使用PYTHON学生通讯录 1:添加学生 2:删除学生 3:修改学生信息 4:搜索学生 5:显示全部学生信息 6:退出并保存 3 庚同硕 123456789 法学 Success {‘张自强’: [‘12652141777’, ‘材料’], ‘庚同硕’: [‘123456789’, ‘法学’], ‘王岩’: [‘11277291473’, ‘文法’]}
示例 1
- 输入:
3
庚同硕
123456789
法学
- 输出:
{'张自强': ['12652141777', '材料'], '庚同硕': ['14388240417', '自动化'], '王岩': ['11277291473', '文法']}欢迎使用PYTHON学生通讯录
1:添加学生
2:删除学生
3:修改学生信息
4:搜索学生
5:显示全部学生信息
6:退出并保存
#输入数据
Success
{'张自强': ['12652141777', '材料'], '庚同硕': ['123456789', '法学'], '王岩': ['11277291473', '文法']}
示例 2
- 输入:
3
王朔
- 输出:
{'张自强': ['12652141777', '材料'], '庚同硕': ['14388240417', '自动化'], '王岩': ['11277291473', '文法']}
欢迎使用PYTHON学生通讯录
1:添加学生
2:删除学生
3:修改学生信息
4:搜索学生
5:显示全部学生信息
6:退出并保存
#输入数据
No Record
{'张自强': ['12652141777', '材料'], '庚同硕': ['14388240417', '自动化'], '王岩': ['11277291473', '文法']}
参考代码
dic = {'张自强': ['12652141777', '材料'], '庚同硕': ['14388240417', '自动化'], '王岩': ['11277291473', '文法']}def menu():print('''\n欢迎使用PYTHON学生通讯录
1:添加学生
2:删除学生
3:修改学生信息
4:搜索学生
5:显示全部学生信息
6:退出并保存''')print(dic)
menu()
n = input()
if n == '3':name = input()if name in dic:dic[name] = [input(), input()]print('Success')else:print('No Record')print(dic)
else:print('ERROR')
第11关:字典增加元素
任务描述
现有字典:
dict1 = {'赵小明': '13299887777', '特明朗': '814666888', '普希京': '522888666', '吴小京': '13999887777'}
尝试向其中加入一个键值对,键和值在两行里输入,如果输入的键在字典中已经存在,则输出“您输入的姓名在通讯录中已存在”,如输入的键在字典中不存在则把键和值加入到字典中。操作完成后输出字典中所有键值对。
输入格式
输入有两行:
第一行是要加入的姓名
第二行是电话号码
输出格式
参考输入输出示例
示例 1
- 输入:
普希京
8589995566
- 输出:
您输入的姓名在通讯录中已存在
示例 2
- 输入:
成龙
8508887777
- 输出:
赵小明:13299887777
特明朗:814666888
普希京:522888666
吴小京:13999887777
成龙:8508887777
参考代码
dic = {'赵小明': '13299887777', '特明朗': '814666888', '普希京': '522888666', '吴小京': '13999887777'}
name = input()
num = input()
if name not in dic:dic[name] = numfor k,v in dic.items():print(f'{k}:{v}')
else:print('您输入的姓名在通讯录中已存在')
第12关:字典的属性、方法与应用
任务描述
将用户输入用逗号分隔的一系列人名做为键,用户输入的逗号分隔的手机号做为值,创建字典MyDict,输入一个正整数 n,你将被要求读入 n 个输入(输入形式如下所示),每得到一个输入后,根据输入进行操作。
add name number: # 在字典中加入以name为键、以number为值的元素
print: # 输出字典
del name: # 删除字典中以name为键的元素,当name不存在时,输出’键不存在’
update name number: # 更新字典中以name为键的元素的值为number
value: # 以列表形式输出字典中的所有值
key: # 以列表形式输出字典中所有键
clear: # 清空字典
输入
第一行输入一个正整数 n
第二行输入用逗号分隔的多个人名
第三行输入的逗号分隔的、与第二行相同数量的手机号
随后的 n 行,每行输入一个如示例格式的命令,命令与参数间空格分隔
输出
每遇到“print”时,在新的一行输出字典
示例 1
- 输入:
8
Tom,Jack,Lee
13988776655,13855664488,13644668888
key
value
print
clear
add ethan 17700001111
add Tom 13988776655
update Tom 13000112222
print
- 输出:
['Tom', 'Jack', 'Lee']
['13988776655', '13855664488', '13644668888']
{'Tom': '13988776655', 'Jack': '13855664488', 'Lee': '13644668888'}
{'ethan': '17700001111', 'Tom': '13000112222'}
参考代码
n = int(input())
dic = dict(zip(input().split(','), input().split(',')))
for i in range(n):order = input().split()if order[0] == 'key':print([x for x in dic])elif order[0] == 'value':print([dic[x] for x in dic])elif order[0] == 'print':print(dic)elif order[0] == 'clear':dic.clear()elif order[0] in ['add', 'update']:dic[order[1]] = order[2]elif order[0] == 'del' :if order[1] in dic:del dic[order[1]]else:print('键不存在')
第13关:查询省会
任务描述
有诗云:
两湖两广两河山,五江云贵福吉安,四西二宁青甘陕,还有内台北上天。
中国各省、直辖市、自治区和特别行政区的字典数据如下:
capitals = {'湖南':'长沙','湖北':'武汉','广东':'广州','广西':'南宁','河北':'石家庄','河南':'郑州','山东':'济南','山西':'太原','江苏':'南京','浙江':'杭州','江西':'南昌','黑龙江':'哈尔滨','新疆':'乌鲁木齐','云南':'昆明','贵州':'贵阳','福建':'福州','吉林':'长春','安徽':'合肥','四川':'成都','西藏':'拉萨','宁夏':'银川','辽宁':'沈阳','青海':'西宁','海南':'海口','甘肃':'兰州','陕西':'西安','内蒙古':'呼和浩特','台湾':'台北','北京':'北京','上海':'上海','天津':'天津','重庆':'重庆','香港':'香港','澳门':'澳门'}`
设计程序,接收用户输入的省、直辖市、自治区和特别行政区名称,输出对应的省会名称,当输入错误时输出“输入错误”。程序可以重复接收用户输入,直接输入回车时退出程序。
输入格式
一个或多个输入
每行输入一个省、直辖市、自治区或特别行政区名称
最后一行输入一个回车
输出格式
输出对应的省会名称
示例 1
- 输入:
新疆
北京
- 输出:
乌鲁木齐
北京
参考代码
capitals = {'湖南':'长沙','湖北':'武汉','广东':'广州','广西':'南宁','河北':'石家庄','河南':'郑州','山东':'济南','山西':'太原','江苏':'南京','浙江':'杭州','江西':'南昌','黑龙江':'哈尔滨','新疆':'乌鲁木齐','云南':'昆明','贵州':'贵阳','福建':'福州','吉林':'长春','安徽':'合肥','四川':'成都','西藏':'拉萨','宁夏':'银川','辽宁':'沈阳','青海':'西宁','海南':'海口','甘肃':'兰州','陕西':'西安','内蒙古':'呼和浩特','台湾':'台北','北京':'北京','上海':'上海','天津':'天津','重庆':'重庆','香港':'香港','澳门':'澳门'}ls1, ls2 = [], []
while 1:city = input()if len(city) == 0:breakelse:ls1.append(city)
for c in ls1:if c in capitals:ls2.append(capitals[c])else:print('输入错误')
print('\n'.join(ls2))
第14关:英汉词典
任务描述
你从武汉搬到美国生活,这里的人都讲英语,你的英语不好,好在你有一个程序,可以把英语译成中文,帮助你与人沟通。
本关所用文件及路径:‘step15/dicts.txt’
下述文件仅用于本地查看文件格式,数据与本关文件不完全相同:
dicts.txt
(注意:词典文件没有精校,存在部分格式不一致的问题,处理时根据空格切分一次,只把英文和中文解释切分开。)
输入
输入一个英文句子
输出
输出英文句子中每个单词的中文意思,每行一个单词,单词字母转小写,“'s” 用 " is"替换,“n’t” 用" not" 替换(替换为空格加is或not),单词与意义间用空格分隔,当查询的词在文件中不存在时,输出’自己猜’
示例 1
- 输入:
For others, but to live for yourself.
- 输出:
for 给,作...用的
others 自己猜
but 但是,除了
to 向,到
live 居住,生存 活的
for 给,作...用的
yourself 你(们)自己
参考代码
import stringdef get_dic(filename):dic = {}with open('/data/bigfiles/dicts.txt', 'r', encoding='utf-8') as f:for x in f.readlines():x = x.replace('生存,', '生存 ').strip().split(maxsplit=1)dic[x[0]] = x[1]return dicdef get_list(sentence):sentence = sentence.replace("n't", ' not').replace("'s", ' is')for x in string.punctuation:sentence = sentence.replace(x, ' ')return sentence.split()def judge(ls, dic):for word in ls:word = word.lower()print(word, dic.get(word, '自己猜'))if __name__ == '__main__':sent = input()filename = 'dicts.txt'dic = get_dic(filename)ls = get_list(sent)
第15关:通讯录(添加)
任务描述
模拟通讯录的数据添加功能。
def menu():print('''\n欢迎使用PYTHON学生通讯录
1:添加学生
2:删除学生
3:修改学生信息
4:搜索学生
5:显示全部学生信息
6:退出并保存''')
dic={'张自强': ['12652141777', '材料'], '庚同硕': ['14388240417', '自动化'], '王岩': ['11277291473', '文法']}
要求编写程序
首先输出字典原始数据,再调用menu函数输出用户选择界面,接下来读用户输入:
(1) 输入‘1’ 进行添加学生,输入姓名,如果该姓名已存在,则输出“Fail”的提示信息,如果不存在,继续输入电话和所在学院。添加完毕后输出“Success”提示信息。
无论是否添加成功,结束后需要输出操作后的字典数据。
(2) 如果输入其他选项,无需再读姓名,直接输出“ERROR”。
输入格式
1 杨彪 11002345678 材料
输出格式
{'张自强': ['12652141777', '材料'], '庚同硕': ['14388240417', '自动化'], '王岩': ['11277291473', '文法']}
欢迎使用PYTHON学生通讯录
1:添加学生
2:删除学生
3:修改学生信息
4:搜索学生
5:显示全部学生信息
6:退出并保存
1
杨彪
11002345678
材料
Success
{'张自强': ['12652141777', '材料'], '庚同硕': ['14388240417', '自动化'], '王岩': ['11277291473', '文法'], '杨彪': ['11002345678', '材料']}
示例 1
- 输入:
1
杨彪
11002345678
材料
- 输出:
{'张自强': ['12652141777', '材料'], '庚同硕': ['14388240417', '自动化'], '王岩': ['11277291473', '文法']}
欢迎使用PYTHON学生通讯录
1:添加学生
2:删除学生
3:修改学生信息
4:搜索学生
5:显示全部学生信息
6:退出并保存
#输入数据
{'张自强': ['12652141777', '材料'], '庚同硕': ['14388240417', '自动化'], '王岩': ['11277291473', '文法'], '杨彪': ['11002345678', '材料']}
示例 2
- 输入:
1
张自强
- 输出:
{'张自强': ['12652141777', '材料'], '庚同硕': ['14388240417', '自动化'], '王岩': ['11277291473', '文法']}欢迎使用PYTHON学生通讯录
1:添加学生
2:删除学生
3:修改学生信息
4:搜索学生
5:显示全部学生信息
6:退出并保存
#输入数据
{'张自强': ['12652141777', '材料'], '庚同硕': ['14388240417', '自动化'], '王岩': ['11277291473', '文法'], '杨彪': ['11002345678', '材料']}
参考代码
dic = {'张自强': ['12652141777', '材料'], '庚同硕': ['14388240417', '自动化'], '王岩': ['11277291473', '文法']}def menu():print('''\n欢迎使用PYTHON学生通讯录
1:添加学生
2:删除学生
3:修改学生信息
4:搜索学生
5:显示全部学生信息
6:退出并保存''')print(dic)
menu()
num = int(input())
if num == 1:name = input()if name in dic:print("Fail")else:dic[name] = [input(), input()]print('Success')print(dic)
else:print("ERROR")