玩了一个假期,是时候整理行装再出发了。从今天开始,每天和大家分享两道关于Python的题目,大家每天花一小时,通过实战学习Python。
1. 有序字符数
计算每个字符的出现次数,并按照出现的顺序将其作为元组列表返回。例如给你一个字符串“abracadabra”,统计里面的字符按照下面的格式输出:ordered_count(“abracadabra”)==[(‘a’,5),(‘b’,2),(‘r’,2),(‘c’,1),(‘d’,1)]
说一下我的思路:首先要把字符串进行拆分,组成一个新的列表,在列表里进行统计,那么分割字符串的做法有很多种,这里介绍两个思路。
一个是用Python的正则对字符串分割:
str = 'abracadabra'
import re
from collections import Counter
list1 = re.findall(r'\w{1,1}',str)
dir1 = Counter(list1)
print(dir1)
另一种最简单的做法就是用list(str)命令:
str = 'abracadabra'
from collections import Counter
list1 = list(str)
dir1 = Counter(list1)
print(dir1)
2. 缩写双字名称
编写一个函数将名称转换为首字母。这个名称严格地用两个词,它们之间有一个1空格。输出应该是两个大写字母,并用点分隔它们。它应该如下所示:
Sam Harris` => S.H
Patrick Feeney` => P.F
逻辑就是把每个单词分离出来,再使用capitalize()函数,最后按照要求方式连接到一起。
这个题目我也写了两种方法,第一种方法都有注释
第二种方法代码更简单
def convert_initial(old:str) -> str:
new = ""
i=0
while i < len(old):
if (i ==0) or (old[i - 1] == " "):
new += old[i].upper()
else:
new += old[i]
i += 1
return new
if __name__ == '__main__':
print(convert_initial('sam harris')[0] + "."+ convert_initial('sam harris')[4])
题目难度对于入门的小白适中,通过题目学习Python,学习更有目的性,缺什么补什么,这样学习起来效率更多。如果大家还有别的更好的解法,欢迎交流你们的想法。
本文提供两道Python编程题:一是计算字符串中字符的有序出现次数;二是实现双字名称的首字母缩写。通过实际操作加深对Python的理解。
11万+

被折叠的 条评论
为什么被折叠?



