盘点Python中断多重循环的思路


本文摘自php中文网,作者爱喝马黛茶的安东尼,侵删。

I. 跳出单循环

不管是什么编程语言,都有可能会有跳出循环的需求,比如枚举时,找到一个满足条件的数就终止。跳出单循环是很简单的,比如:

1

2

3

4

for i in range(10):

    if i > 5:

        print i

        break

然而,我们有时候会需要跳出多重循环,而break只能够跳出一层循环,比如:

1

2

3

4

5

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的标准语法是不支持跳出多重循环的,所以只能利用一些技巧,大概的思路有:写成函数、利用笛卡尔积、利用调试。

当然最常用的思路是使用变量标记法

1

2

3

4

5

6

7

8

9

10

11

12

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这一句就会停止,因此可以利用这一特性,将功能写成函数,终止多重循环。

例如:

1

2

3

4

5

6

def work():

    for i in range(10):

        for j in range(10):

            if i+j > 5:

                return i,j

print work()

利用笛卡尔积

这种方法的思路就是,既然可以跳出单循环,我就将多重循环改写为单循环,这可以利用itertools中的笛卡尔积函数product,例如:

1

2

3

4

5

from itertools import product

for i,j in product(range(10), range(10)):

    if i+j > 5:

        print i,j

        break

利用调试模式

笛卡尔积的方式很巧妙,也很简洁,但它只能用于每次循环的集合都是独立的情形,假如每层循环都与前一层紧密相关,就不能用这种技巧了。这时候可以用第一种方法,将它写成函数,另外,还可以利用调试模式。这个利用了调试模式中,只要出现报错就退出的原理,它伪装了一个错误出来。

1

2

3

4

5

6

7

8

9

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中断多重循环的思路的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

Python md5与sha1加密算法的详细介绍

Python接单平台有哪些

Python字典能用来干什么

Python中导入模块中的对象有哪几种方式

Python什么时候用多进程编程

Python中转换模块codecs的讲解(附示例)

Python里的end是什么意思

大学有Python课吗

Python获取程序执行文件路径的方法

Python的基本数据类型有哪些?

更多相关阅读请进入《Python》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...