了解Python的小伙伴都知道Python虽然入门容易,但是涉及的知识超级多,而且技巧性很强!这些技巧就像锁链一样,需要一些勤加练习才能熟练掌握起来,把知识点掌握牢固!今天小编就为大家精选了3道趣味的Python题目,大家一起活动手指,练起来吧!
下面小编带大家看看菜鸟和高手是分别是如何处理问题:
NO.1字符串中的字符替换
字符串是Python中最基本也是最重要的知识点,下面这道题是关于字符串替换。
创建一个函数,这个函数能把输入的字符串进行处理,并将返回替换了某些字符的字符串,规则如下
· 如果一个字母是大写辅音,请将该字符替换为“Iron”。
· 如果字母是小写辅音或非字母字符,则对该字符不执行任何操作
· 如果一个字母是大写元音,请将该字符替换为“Iron Yard”。
· 如果一个字母是小写元音,请用“Yard”替换该字符。
测试用例
输入: "Hello WORLD!"
输出: "IronYardllYard IronIron YardIronIronIron!"
菜鸟解法:def replace_str(string):
res = ""
vowel = 'aeiou'
for i in string:
if i in vowel:
res += 'Yard'
elif i in vowel.upper():
res += 'Iron Yard'
elif i.isupper():
res +='Iron'
else:
res += i
return res
print(replace_str('Hello WORLD!'))
大神解法:def tiy_fizz_buzz(s):
return "".join(("Iron "*c.isupper() + "Yard"*(c.lower() in "aeiou")).strip() or c for c in s)
点评:
高手解法最巧妙不是用类似推到列表这样的方法来循环处理字符串,而且非常巧妙的用"Iron"*True 或者"Iron"*False,如果是前者则为字符串本身,而后者则为空""。然后在把两个字符串用+合成,再用or分类!完美把上面的if-elif-elif-else融合到了一行代码里面,确实不错!
NO.2趣味体重排序
小丽在一个"减肥会所",每到月底小丽就很担心,因为每个月都会公布一份成员体重列表,每个月她都是列表中的最后一个,这意味着她是最重的。于是她就建议会长修改规则,比如新的规则如下:
新的排序规则将是按照“权重”来进行排序,如果权重相同,则按照体重字符串来进行排序。(权重的计算规则:体重数字不同位数上的数字的总和)
给定某种正常顺序俱乐部的成员的体重字符串,如何实现按照新规则排序呢?
测试用例:
输入: "99 189 86 75"
输出: "75 86 189 99"
菜鸟解法:def order_weight(string):
weight_list = string.split(' ')
def helper(x):
if not x:
return x
y = int(x)
z = 0
while y:
z += y % 10
Y = int(y / 10)
return (z,x)
weight_list.sort.sort(key = helper)
return " ".join(weight_list)
大神解法:def order_weight(_str):
return' '.join(sortsd(_str.split(' '),key = lambda x: sum(int(c) for c in x)))
点评:
高手的解法同样是比较简洁!我们大部分人用for c in x 的时候都用到这一层就结束了,其实还可以对c再进行进一步操作然后再sum一下,这个例子可以举一反三!一下子集合了很多sorted的高级用法,简洁而有效!
3.扔骰子游戏
用五个六面骰子玩的骰子游戏,每投骰子组一次,就会出现5个数字的数组(数字:1-6),统计数组里每个数字出现的次数,将每个数字出现的次数拆分成 3次 和 1次 的组合,然后按照下面的规则进行计数。 注意:如果出现次数大于或者等于3次,那么必须至少有一个按照3次来计算,不能全部按照1次来计算
3次1 = = 1000分 3次6 = = 600分
3次5 = = 500分 3次4 = = 400分
3次3 = = 300分 3次2 = = 200分
1次1 => 100分 1次5 => 50分
1次2 => 0分 1次3 => 0分
1次4 => 0分 1次6 => 0分
例如,5出现了5次,那么应当做作3个5、1个5和1个5来计算得分;5出现了6次,那么应当作3个5、3个5来计算得分,其他数字同理。
测试用例:
扔骰子计算得分
5 1 3 4 1 50 + 2 * 100 = 250
1 1 1 3 1 1000 + 100 = 1100
2 4 4 5 4 400 + 50 = 450
菜鸟解法:from collections import Counter
def score(dice):
num_dict = dict(Counter(dice))
res = 0
for i in num_dict:
if i == 1:
res +=1000 * (int(num_dict[i] / 3)) + 100 * (num_dict[i] % 3)
elif i == 5:
res +=500 * (int(num_dict[i])) + 50 * (num_dict[i] % 3)
else:
res += 100 * (i * int(num_dict[i] / 3))
return res
大神解法:def score(dice):
sum = 0
counter = [0,0,0,0,0,0]
points = [1000, 200, 300, 400, 500, 600]
extra = [100,0,0,0,50,0]
for die in dice:
counter[die-1] += 1
for (i, count) in enumerate(counter):
sum += (points[i] if count >= 3 else 0) + extra[i] * (count%3)
return sum
点评:
大神的解法在于设计的数据结构非常巧,提前根据题目的意思就设计好了几个容器,然后counter列表巧妙的将(1-6)与(1-6)出现的次数关联起来。points和extra列表巧妙将数字出现的次数(3次和1次)和得分关联表示,减少误输得分的情况,提高代码重复利用,整个解法非常巧妙!
上面这几道题目看起来很简单易懂,但是解法就是没有别人的简洁巧妙!就好像厨艺大赛,看似一道简单的蛋炒饭其实是非常考验功底的!编程本身就是蕴含算法+数据结构的融合,大家有空可以多学习学习优秀的代码,对自己学习提升都大有好处!