当前位置: 代码迷 >> C语言 >> [求助]为什么会这样写
  详细解决方案

[求助]为什么会这样写

热度:266   发布时间:2007-05-16 17:18:38.0
[求助]为什么会这样写
#include<math.h>
main()
{ int i,j,line,a[101];
for(i=2;i<101;i++) a[i]=i;
for(i=2;i<sqrt(101);i++)/*为什么是sqrt(101),我不理解,请指教*/
for(j=i+1;j<101;j++)
{ if(a[i]!=0&&a[j]!=0)/*为什么非有这句话?*/
if(a[j]%a[i]==0)
a[j]=0;}
printf("\n");
for(i=2,line=0;i<101;i++)
{ if(a[i]!=0)
{ printf("%5d",a[i]);
line++;}
if(line==10)
{ printf("\n");
line=0;}
}
}
题目: 用筛选法求100之内的素数
搜索更多相关的解决方案: include  

----------------解决方案--------------------------------------------------------
因为在sqrt(n)之后就不会出现了...

只为了减少运算时间而已...
----------------解决方案--------------------------------------------------------
那第二个呢?
他有啥用?

[此贴子已经被作者于2007-5-16 18:46:59编辑过]


----------------解决方案--------------------------------------------------------

是为了(a[i]!=0&&a[j]!=0)中的a[i]!=0减少第一个循环的次数.如果a[i]==0了,a[i]==0之前a[i]一定是个能被整除的数,所以此时的a[i]就没有必要作为被除数了。
(a[i]!=0&&a[j]!=0)中的a[j]!=0是为了减少第二个循环中的数字运算的次数,第一次被否认了,就不会在再一次的循环中参与运算了。


----------------解决方案--------------------------------------------------------
  相关解决方案