虽然最早就学过
while与do-while区别
但因为do-while很少用
甚至做题时可以说从来没用过
所以对于描述
do-while的循环体至少会执行一次
这句话并没有深刻体会
不过引发这个思考的是
【NYOJ】[56]阶乘因式分解(一)
之中的for循环条件for(int k=i; !(k%m); cnt++)
!(k%m)
含义有点困惑
不过结合 while do-while 便可以轻松得出
for(初始语句;判断语句;调整语句)
中在执行循环的顺序应该是
flowchart TD st[初始语句] --> cond{循环条件} cond -- 是 --> op1[循环体] cond -- 否 --> e[循环结束] op1 --> op2[调整语句] op2 --> cond
这个流程图画的还不错吧~哈哈哈
验证:
初始条件在第一次判断前就执行
|
|
第一次循环体执行前就需要 判断条件:
|
|
而do-while形式为
|
|
两次输出都为 n的值为1
由此可以验证
for 与 do-while的区别