我很傻吗 发表于 2021-3-11 14:42:47

请问下这个程序应该如何优化

pw = "FishC.com"
temp = input("请输入密码:")
count = 3
while count != 0:
    for each in temp:
      if each == "*":
            temp = input("密码中不能含有“*”号!您还有"+str(count)+"次机会!请输入密码:")
      continue
    if temp == pw:
      print("密码正确,进入程序......")
      break
    else:
      count = count - 1
      temp = input("密码输入错误!您还有"+str(count)+"次机会!请输入密码:")
      continue
if count == 0:
    print("机会没了")

在输入有*的密码后,他都会输出与*数量相同的回答回来,无法直接进入下一次输入密码,例如我输入*****,他会返回

请输入密码:*****
密码中不能含有“*”号!您还有3次机会!请输入密码:1
密码中不能含有“*”号!您还有3次机会!请输入密码:2
密码中不能含有“*”号!您还有3次机会!请输入密码:3
密码中不能含有“*”号!您还有3次机会!请输入密码:4
密码中不能含有“*”号!您还有3次机会!请输入密码:4
密码输入错误!您还有2次机会!请输入密码:5

只有在第六次的时候才能进入下一次,请问大佬们这该如何解决,谢谢啦

笨鸟学飞 发表于 2021-3-11 15:00:22

pw = "FishC.com"
count = 3
while count:
    temp = input("请输入密码:")
    if "*" in temp:
      print("密码中不能含有‘*’!您还有%d次机会!" % count)
      continue
    count -= 1
    if temp == pw:
      print("密码正确,进入程序......")
      break
    elif count == 0:
      print("密码输入错误!您已经没机会了,Game over!")
      break
    else:
      print("密码输入错误!您还有%d次机会!" % count)
      continue

逃兵 发表于 2021-3-11 15:00:56

pw = "FishC.com"
temp = input("请输入密码:")
count = 2
while count != 0:
    count = count - 1
    if '*' in temp:
      temp = input("密码中不能含有“*”号!您还有"+str(count+1)+"次机会!请输入密码:")
      continue
      

    if temp == pw:
      print("密码正确,进入程序......")
      break
    else:
      
      temp = input("密码输入错误!您还有"+str(count+1)+"次机会!请输入密码:")
      continue
if count == 0:
    print("机会没了")

弈秋呜呜呜 发表于 2021-3-11 15:28:10

本帖最后由 弈秋呜呜呜 于 2021-3-11 15:30 编辑

你这个是对于循环的理解还欠缺,只要把for循环里的 continue 换成 break 就解决了。不然你一旦输入 * ,就会先在for循环里吧你输入的* 遍历完,才会执行剩下的语句。还有,其实你可以直接用if判断,用for就有点多此一举了。
temp = input("请输入密码:")
count = 3
while count > 1:
    for each in temp:
      if each == "*":
            temp = input("密码中不能含有“*”号!您还有"+str(count)+"次机会!请输入密码:")
      break
    if temp == pw:
      print("密码正确,进入程序......")
      break
    else:
      count = count - 1
      temp = input("密码输入错误!您还有"+str(count)+"次机会!请输入密码:")
      continue
if count:
    print("机会没了")

我很傻吗 发表于 2021-3-11 15:32:39

弈秋呜呜呜 发表于 2021-3-11 15:28
你这个是对于循环的理解还欠缺,只要把for循环里的 continue 换成 break 就解决了。不然你一旦输入 * ,就 ...

请问break的缩进对于跳出循环有影响吗,这个break跳出的是for循环吗

我很傻吗 发表于 2021-3-11 15:38:29

弈秋呜呜呜 发表于 2021-3-11 15:28
你这个是对于循环的理解还欠缺,只要把for循环里的 continue 换成 break 就解决了。不然你一旦输入 * ,就 ...

但是如果是continue的话 因为在输入*后我有加一个temp=input,那temp不应该已经被修改了吗,那他重新进入循环的话,我的理解是对这个新的temp遍历然后找有没有*,为什么还是上一个输入的temp呢

yuedong 发表于 2021-3-11 15:42:27

我是这样改的,break的话应该只会跳出当前的for,while等循环,只跳出一层

pw = "FishC.com"
temp = input("请输入密码:")
count = 3
sign = False
while 1:
    for each in temp:
      if each == "*":
            temp = input("密码中不能含有“*”号!您还有"+str(count)+"次机会!请输入密码:")
            sign = True
            break
      else:
            sign = False
    if sign:
      continue
      
    if temp == pw:
      print("密码正确,进入程序......")
      break
    elif count >0:
      print("密码输入错误!",end = ' ')
      count = count - 1
      if count ==0:
            print("机会没了!!!")
            break
    temp = input("您还有"+str(count)+"次机会!请输入密码:")
    continue

我很傻吗 发表于 2021-3-11 15:56:56

yuedong 发表于 2021-3-11 15:42
我是这样改的,break的话应该只会跳出当前的for,while等循环,只跳出一层

谢谢哥!你这个结构太强了

弈秋呜呜呜 发表于 2021-3-11 19:01:14

我很傻吗 发表于 2021-3-11 15:38
但是如果是continue的话 因为在输入*后我有加一个temp=input,那temp不应该已经被修改了吗,那他重新进入 ...

因为你是用continue 来进行下一次循环,这时for循环没有停止,所以迭代的对象仍然是第一个temp,你第二次所赋值的temp要等到for循环结束后,才会覆盖原先的temp,被之后代码所用。也就是说用continue的话要等到先把你第一次的temp遍历完才会去判断你之后的temp。而用break就是强制终止循环,旧的新的temp会覆盖旧的temp去执行接下来的代码。

我很傻吗 发表于 2021-3-15 10:48:28

弈秋呜呜呜 发表于 2021-3-11 19:01
因为你是用continue 来进行下一次循环,这时for循环没有停止,所以迭代的对象仍然是第一个temp,你第二次 ...

懂了,谢谢哥
页: [1]
查看完整版本: 请问下这个程序应该如何优化