求解:
为什么int flag=1放在for外面就出错了,而把int flag=1放在for里面又正常了呢?
#include
int main()
{
int i,j;
int flag=1;
for(i=2;i<=100;i++)
{
for(j=2;j<i;j++)
{
if(i%j==0){flag=0;break;}
}
if(flag) printf("%d ",i);
}
return 0;
}
编码实现不符合预期,原有程序第一次进入内循环后,flag会赋值为0,结果将导致内for循环始终保持空转情况,if(flag)始终无法成立。修改方法需要在第一个for循环中增加赋值语句:flag=1;
你要是放外面的话,执行if(i%j==0){flag=0;break;}这句话后,flag的值被赋值为0,那它往后再执行的话flag一直就是0,所以不会打印输出了,你要看清楚了,break只是退出内循环,在退出内循环后你要把flag再次置为1才能打印输出,所以int flag=1 你要放在for里面
#include
int main()
{
int i,j;
for(i=2;i<=100;i++)
{
int flag=1;
for(j=2;j<i;j++)
{
if(i%j==0){flag=0;break;}
}
if(flag) printf("%d ",i);
}
system("PAUSE");
return 0;
}
这样就对了