Ari小虎鱼 发表于 2022-4-10 12:42:35

第016讲课后作业

Python016讲课后作业最后一题原文链接打不开啊,有没有好心人发下代码

andy大宝 发表于 2022-4-10 20:30:31

本帖最后由 andy大宝 于 2022-4-10 20:32 编辑

能截个图或者发一下原文吗{:10_245:}为了解答问题再花10鱼币了属于是{:10_266:}

发一下有问题的部分就行{:10_277:}

Ari小虎鱼 发表于 2022-4-11 07:57:11

本帖最后由 Ari小虎鱼 于 2022-4-11 07:59 编辑

andy大宝 发表于 2022-4-10 20:30
能截个图或者发一下原文吗为了解答问题再花10鱼币了属于是

发一下有问题的部分就行 ...

不会截图{:10_333:}
原文是这个:
2. 终极考验:编写代码,让程序分别统计正反面最多出现连续的次数。
要求:不要使用超纲的知识
提醒:该题比较搞逻辑,但耐下心来死磕的话,小甲鱼相信你是可以完成的,加油

andy大宝 发表于 2022-4-11 08:14:17

Ari小虎鱼 发表于 2022-4-11 07:57
不会截图
原文是这个:
2. 终极考验:编写代码,让程序分别统计正反面最多出现连续的次数 ...

抛硬币是吗{:10_257:}

andy大宝 发表于 2022-4-11 09:05:47

本帖最后由 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))

Ari小虎鱼 发表于 2022-4-11 21:10:54

andy大宝 发表于 2022-4-11 09:05
我的代码有些繁琐应该有更好的方法,先理解一下,之后学到列表可以更快一些

感谢大佬的帮助!!!
页: [1]
查看完整版本: 第016讲课后作业