C语言_break和return 0的区别
下列代码中黄色加深处若使用break 输入10时,获取的结果不止1个,结果见下图
若使用return 0,获取的结果则只有1个,就是图片中结果的第一种
请问造成这个的原因是什么?
#include <stdio.h>
int main()
{
int a,iSum = 0,i,j,cubed;
printf("请输入一个整数:");
scanf("%d", &a);
cubed = (a * a*a);
for (j = 1; j < (cubed);j += 2)
for (i = j; i <= (cubed);)
{
iSum += i;
if (iSum == cubed)
{
printf("%d = %d + %d ... + %d", cubed, j, j + 2, i);
break;
}
if (iSum > cubed)
{
iSum = 0; //这里遗漏了将iSum清零的步骤
break;
}
i += 2;
}
} 本帖最后由 superbe 于 2019-10-7 16:36 编辑
break只是退出内层for循环,会接着继续执行外层的循环,而return直接退出main函数了,所以只有一个结果。
这个break前面应该有iSum=0; superbe 发表于 2019-10-7 16:21
break只是退出内层for循环,会接着继续执行外层的循环,而return直接退出main函数了,所以只有一个结果。
...
好的,明白,感恩! superbe 发表于 2019-10-7 16:21
break只是退出内层for循环,会接着继续执行外层的循环,而return直接退出main函数了,所以只有一个结果。
...
还是想请问一下下为什么break前面要加个iSum = 0?
观察并未在break前加iSum=0输出来的结果虽然有多个,但是却并未有错?所以不懂这么做的意义 superbe 发表于 2019-10-7 16:21
break只是退出内层for循环,会接着继续执行外层的循环,而return直接退出main函数了,所以只有一个结果。
...
经您这么一说,我又有一点小问题了,就是为啥能输出这么多个结果?
当iSum = cubed时,使用break提前结束当前内循环(i那部分),此时的iSum已经是cubed值了,为啥在退出内循环(i那部分),再重新循环时还能继续计算?是因为再计算式,iSum就会>cubed,所以被清零后,再重新进行计算?
感觉应该是这样{:5_99:} 可以不加。
当满足iSum == cubed时,如果不加iSum=0,下一次计算iSum += i; 时是在1000的基础上累加的,应该是从0累加才对。
但是这种情况下会继续执行下面的if (iSum > cubed){iSum = 0; 可以不加。
页:
[1]