第016讲课后作业
Python016讲课后作业最后一题原文链接打不开啊,有没有好心人发下代码 本帖最后由 andy大宝 于 2022-4-10 20:32 编辑能截个图或者发一下原文吗{:10_245:}为了解答问题再花10鱼币了属于是{:10_266:}
发一下有问题的部分就行{:10_277:} 本帖最后由 Ari小虎鱼 于 2022-4-11 07:59 编辑
andy大宝 发表于 2022-4-10 20:30
能截个图或者发一下原文吗为了解答问题再花10鱼币了属于是
发一下有问题的部分就行 ...
不会截图{:10_333:}
原文是这个:
2. 终极考验:编写代码,让程序分别统计正反面最多出现连续的次数。
要求:不要使用超纲的知识
提醒:该题比较搞逻辑,但耐下心来死磕的话,小甲鱼相信你是可以完成的,加油 Ari小虎鱼 发表于 2022-4-11 07:57
不会截图
原文是这个:
2. 终极考验:编写代码,让程序分别统计正反面最多出现连续的次数 ...
抛硬币是吗{:10_257:} 本帖最后由 andy大宝 于 2022-4-11 09:07 编辑
我的代码有些繁琐{:10_245:}应该有更好的方法,先理解一下,之后学到列表可以更快一些{:10_275:}
import random
temp = int(input("请输入抛硬币次数:"))
count = 0 #抛硬币次数
last = 0 #最后一次抛硬币正反
maxz = 0 #正面最多连续出现的次数
maxf = 0 #反面最多连续出现的次数
nc = 0 #最后一次连续出现的次数
while count < temp:
count = count + 1
secret = random.randint(1,2) #1代表正,2代表反
if secret == 1: #虽然用数字代表正反,但打印时需要转换
print("正",end=" ")
else:
print("反",end=" ")
if secret == last: #如果连续
nc = nc + 1
else: #如果不连续
if last == 1: #如果最后一次连续为正面
if maxz < nc:
maxz = nc
else:
if maxf < nc: #第一轮循环不会受到影响
maxf = nc
last = secret #为下一轮循环初始化
nc = 1 #包括这一轮循环,也连续出现过一次
if last == 1: #最后一轮还需要判断一次
if maxz < nc:
maxz = nc
else:
if maxf < nc:
maxf = nc
print()
print("正面最多连续出现的次数为:" + str(maxz))
print("反面最多连续出现的次数为:" + str(maxf))
andy大宝 发表于 2022-4-11 09:05
我的代码有些繁琐应该有更好的方法,先理解一下,之后学到列表可以更快一些
感谢大佬的帮助!!!
页:
[1]