视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
非常适合菜鸟练手的3道趣味Python题
2020-11-27 14:11:11 责编:小OO
文档
 了解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 1 86 75" 输出: "75 86 1 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次)和得分关联表示,减少误输得分的情况,提高代码重复利用,整个解法非常巧妙!

上面这几道题目看起来很简单易懂,但是解法就是没有别人的简洁巧妙!就好像厨艺大赛,看似一道简单的蛋炒饭其实是非常考验功底的!编程本身就是蕴含算法+数据结构的融合,大家有空可以多学习学习优秀的代码,对自己学习提升都大有好处!

【推荐课程:Python专栏视频教程】

下载本文
显示全文
专题