python - 似乎这里的“中断”不起作用
问题描述
这是代码:
for i in range(12):
for j in range(8):
if i == j:
break
print i
print j
我的想法是:起初 i 等于 0,j 等于 0。这与
我 == j
条件等等
休息
会被触发。然后它将退出最里面的 for 循环。所以 j 的值为 0。由于外部 for 循环没有退出,我将继续循环遍历 range(12) 中的所有元素,最后我将被分配 11。所以当我打印值时i 和 j 中,它们分别是 11 和 d 0。
然而结果是:
i = 11 和 j == 7
我想知道我上述论点的哪一部分出了问题。
解决方案
使用您的代码,输出如下。因此,结果完全符合预期,并且 break 运行良好。
当 everi == j
为真时,内循环存在但外循环仍在运行,并再次循环内循环,直到i==j
满足或内循环完全迭代。因此最终输出为i = 11 ; j = 7
,最终结果。
print 'i','j'
for i in range(12):
for j in range(8):
print i, j
if i == j:
#print " yes "
break
print "---------"
print i
print j
输出是:
i j
0 0
---------
1 0
1 1
---------
2 0
2 1
2 2
---------
3 0
3 1
3 2
3 3
---------
4 0
4 1
4 2
4 3
4 4
---------
5 0
5 1
5 2
5 3
5 4
5 5
---------
6 0
6 1
6 2
6 3
6 4
6 5
6 6
---------
7 0
7 1
7 2
7 3
7 4
7 5
7 6
7 7
---------
8 0
8 1
8 2
8 3
8 4
8 5
8 6
8 7
---------
9 0
9 1
9 2
9 3
9 4
9 5
9 6
9 7
---------
10 0
10 1
10 2
10 3
10 4
10 5
10 6
10 7
---------
11 0
11 1
11 2
11 3
11 4
11 5
11 6
11 7
---------
11
7
推荐阅读
- laravel - 使用 laravel 的 cron 作业向用户发送电子邮件
- python - Connecting Google Apps Script to personal computer to run a program
- python - 为什么在 Python 中无法访问属性?
- sql - How I can extract year from a date in sql and use it in where clause
- llvm - LLVM 依赖分析是否能够输出存储和加载以外的两条指令之间的依赖关系?
- google-bigquery - BigQuery Standard SQL automatically replace null with zero on left join
- java - 套接字连接被丢弃
- android - 如何保存和加载布尔数组 Android Studio
- xamarin.forms - Xamarin Forms Shell TitleView 不居中图像
- flutter - 颤振 CustomPaint 和 GestureDetector 都调整为图像大小