当前位置: 首页>编程语言>正文

python编程大赛题目选择题 python趣味编程比赛题目

了解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次)和得分关联表示,减少误输得分的情况,提高代码重复利用,整个解法非常巧妙!

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


https://www.xamrdz.com/lan/5e61944382.html

相关文章: