I. 跳出单轮回
不论是什么编程言语,都有能够会有跳出轮回的需求,比方罗列时,找到一个满足前提的数就住手。跳出单轮回是很简单的,比方:
for i in range(10): if i > 5: print i break
但是,我们有时候会须要跳出多重轮回,而break只能够跳出一层轮回,比方:
for i in range(10): for j in range(10): if i+j > 5: print i,j break
如许的代码并非说找到一组 i+j > 5就住手,而是一连找到10组,由于break只跳出了for j in range(10)这一重轮回。那末,怎样才跳出多重呢?在此纪录备忘一下。
相干引荐:《Python教程》
II. 跳出多重轮回
事实上,Python的规范语法是不支持跳出多重轮回的,所以只能应用一些技能,也许的思绪有:写成函数、应用笛卡尔积、应用调试。
固然最经常运用的思绪是运用变量标记法
def f(): flag = 0 for i in range(10): for j in range(i): if i+j>5: print i,j flag = 1 break if flag == 1: break if __name__ == "__main__": f()
写成函数
在Python中,函数运转到return这一句就会住手,因而能够应用这一特征,将功用写成函数,住手多重轮回。
比方:
def work(): for i in range(10): for j in range(10): if i+j > 5: return i,j print work()
应用笛卡尔积
这类要领的思绪就是,既然能够跳出单轮回,我就将多重轮回改写为单轮回,这能够应用itertools中的笛卡尔积函数product,比方:
from itertools import product for i,j in product(range(10), range(10)): if i+j > 5: print i,j break
应用调试形式
笛卡尔积的体式格局很奇妙,也很简约,但它只能用于每次轮回的鸠合都是自力的情况,如果每层轮回都与前一层严密相干,就不能用这类技能了。这时候能够用第一种要领,将它写成函数,别的,还能够应用调试形式。这个应用了调试形式中,只需涌现报错就退出的道理,它伪装了一个毛病出来。
class Found(Exception): pass try: for i in range(10): for j in range(i): #第二重轮回跟第一重有关 if i + j > 5: raise Found except Found: print i, j
以上就是清点Python中断多重轮回的思绪的细致内容,更多请关注ki4网别的相干文章!