请问下这个程序应该如何优化
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
只有在第六次的时候才能进入下一次,请问大佬们这该如何解决,谢谢啦 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 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: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:28
你这个是对于循环的理解还欠缺,只要把for循环里的 continue 换成 break 就解决了。不然你一旦输入 * ,就 ...
请问break的缩进对于跳出循环有影响吗,这个break跳出的是for循环吗 弈秋呜呜呜 发表于 2021-3-11 15:28
你这个是对于循环的理解还欠缺,只要把for循环里的 continue 换成 break 就解决了。不然你一旦输入 * ,就 ...
但是如果是continue的话 因为在输入*后我有加一个temp=input,那temp不应该已经被修改了吗,那他重新进入循环的话,我的理解是对这个新的temp遍历然后找有没有*,为什么还是上一个输入的temp呢 我是这样改的,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
yuedong 发表于 2021-3-11 15:42
我是这样改的,break的话应该只会跳出当前的for,while等循环,只跳出一层
谢谢哥!你这个结构太强了 我很傻吗 发表于 2021-3-11 15:38
但是如果是continue的话 因为在输入*后我有加一个temp=input,那temp不应该已经被修改了吗,那他重新进入 ...
因为你是用continue 来进行下一次循环,这时for循环没有停止,所以迭代的对象仍然是第一个temp,你第二次所赋值的temp要等到for循环结束后,才会覆盖原先的temp,被之后代码所用。也就是说用continue的话要等到先把你第一次的temp遍历完才会去判断你之后的temp。而用break就是强制终止循环,旧的新的temp会覆盖旧的temp去执行接下来的代码。 弈秋呜呜呜 发表于 2021-3-11 19:01
因为你是用continue 来进行下一次循环,这时for循环没有停止,所以迭代的对象仍然是第一个temp,你第二次 ...
懂了,谢谢哥
页:
[1]