Python中斷多重循環的幾種思路

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)這一重循環。那麼,怎麼才能跳出多重呢?在此記錄備忘一下。函數

II. 跳出多重循環

事實上,Python的標準語法是不支持跳出多重循環的,因此只能利用一些技巧,大概的思路有:寫成函數、利用笛卡爾積、利用調試。spa

寫成函數

在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,例如code

from itertools import product

for i,j in product(range(10), range(10)):
    if i+j > 5:
        print i,j
        break

利用調試模式

笛卡爾積的方式很巧妙,也很簡潔,但它只能用於每次循環的集合都是獨立的情形,假如每層循環都與前一層緊密相關,就不能用這種技巧了。這時候能夠用第一種方法,將它寫成函數,另外,還能夠利用調試模式。這個利用了調試模式中,只要出現報錯就退出的原理,它假裝了一個錯誤出來。blog

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
相關文章
相關標籤/搜索