Rumah > pembangunan bahagian belakang > Tutorial Python > 非常适合菜鸟练手的3道趣味Python题

非常适合菜鸟练手的3道趣味Python题

little bottle
Lepaskan: 2019-04-04 11:09:48
asal
3550 orang telah melayarinya

了解Python的小伙伴都知道Python虽然入门容易,但是涉及的知识超级多,而且技巧性很强!这些技巧就像锁链一样,需要一些勤加练习才能熟练掌握起来,把知识点掌握牢固!今天小编就为大家精选了3道趣味的Python题目,大家一起活动手指,练起来吧!

3-1Z121222647.jpg

下面小编带大家看看菜鸟和高手是分别是如何处理问题:

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!'))
Salin selepas log masuk

大神解法:

def tiy_fizz_buzz(s):
   return "".join(("Iron "*c.isupper() + "Yard"*(c.lower() in "aeiou")).strip() or c for c in s)
Salin selepas log masuk

点评:

高手解法最巧妙不是用类似推到列表这样的方法来循环处理字符串,而且非常巧妙的用"Iron"*True 或者"Iron"*False,如果是前者则为字符串本身,而后者则为空""。然后在把两个字符串用+合成,再用or分类!完美把上面的if-elif-elif-else融合到了一行代码里面,确实不错!

NO.2趣味体重排序

1554347153624233.jpg

小丽在一个"减肥会所",每到月底小丽就很担心,因为每个月都会公布一份成员体重列表,每个月她都是列表中的最后一个,这意味着她是最重的。于是她就建议会长修改规则,比如新的规则如下:

新的排序规则将是按照“权重”来进行排序,如果权重相同,则按照体重字符串来进行排序。(权重的计算规则:体重数字不同位数上的数字的总和)

给定某种正常顺序俱乐部的成员的体重字符串,如何实现按照新规则排序呢? 测试用例: 输入: "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)
Salin selepas log masuk

大神解法:

def order_weight(_str):
    return' '.join(sortsd(_str.split(' '),key = lambda x: sum(int(c) for c in x)))
Salin selepas log masuk

点评:

高手的解法同样是比较简洁!我们大部分人用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
Salin selepas log masuk

大神解法:

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
Salin selepas log masuk

点评:

大神的解法在于设计的数据结构非常巧,提前根据题目的意思就设计好了几个容器,然后counter列表巧妙的将(1-6)与(1-6)出现的次数关联起来。points和extra列表巧妙将数字出现的次数(3次和1次)和得分关联表示,减少误输得分的情况,提高代码重复利用,整个解法非常巧妙!

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

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


Atas ialah kandungan terperinci 非常适合菜鸟练手的3道趣味Python题. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan