zoukankan      html  css  js  c++  java
  • python跳出多重循环的方法

    学了java跳出多重循环的方法,也搜索了python跳出多重循环的方法,原文详见:https://blog.csdn.net/churximi/article/details/51043595

    方法1:自定义异常

    # -*- coding:utf-8 -*-
    
    """
    功能:python跳出循环
    """
    # 方法1:自定义异常
    
    
    class Getoutofloop(Exception):
        pass
    try:
        for i in range(5):
            for j in range(5):
                 if i == j == 2:
                      raise Getoutofloop()
                 else:
                       print i, '----', j
    except Getoutofloop:
          pass

    方法2:将循环封装为函数,return

    # -*- coding:utf-8 -*-

    """
    功能:python跳出循环
    """
    # 方法2:封装为函数,return

    def test():
         for i in range(5):
              for j in range(5):
                   if i == j == 2:
                        return
                   else:
                         print i, '----', j
    
    test()        

    方法3:用for...else...语句

    # -*- coding:utf-8 -*-

    """
    功能:python跳出循环
    """
    # 方法2:for...else...用法,用于跳出指定循环层

    # -*- coding:utf-8 -*-
    
    """
    功能:python跳出循环
    """
    # 方法2:for...else...用法,用于跳出指定循环层
    
    for i in range(5):
        for j in range(5):
            for k in range(5):
                if i == j == k == 3:
                    break
                else:    
                    print i, '----', j, '----', k
            else:        # else1
                continue
            break        # break1
        else:            # else2
            continue
        break            # break2


    方法3解释:
    (1)break能跳出某一重循环(该重循环的本次及剩余次数都不再执行),但并不能跳出该重循环的其他外重循环。

    例如,最内第3重循环break之后,程序返回第2重循环继续执行第2重的下一次,然后第3重循环将再次执行。

    (2)continue是跳过某一重循环的某一次,但该重循环的剩余次数会继续执行。

    (3)for...else:其中else块中的语句将在for循环完整执行过之后才会被执行,如果for循环被break,则else块将不会被执行。

    (4)方法3中,当第3重循环满足i == j == k ==3时,第3重循环被break,则并列的else1将跳过,执行break1,导致第2重循环

    被终止,则else2被跳过,执行break2,导致第1重循环被终止。

    最终实现跳出整个循环。

  • 相关阅读:
    BZOJ 2821: 作诗(Poetize)( 分块 )
    BZOJ 2440: [中山市选2011]完全平方数( 二分答案 + 容斥原理 + 莫比乌斯函数 )
    BZOJ 1058: [ZJOI2007]报表统计( 链表 + set )
    BZOJ 1034: [ZJOI2008]泡泡堂BNB( 贪心 )
    BZOJ 1016: [JSOI2008]最小生成树计数( kruskal + dfs )
    BZOJ 2329: [HNOI2011]括号修复( splay )
    BZOJ 3143: [Hnoi2013]游走( 高斯消元 )
    BZOJAC400题留念
    BZOJ 2982: combination( lucas )
    poj 3233
  • 原文地址:https://www.cnblogs.com/linwenbin/p/11097638.html
Copyright © 2011-2022 走看看