| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 894 人关注过本帖
标题:用筛法求素数的问题!
只看楼主 加入收藏
无心剑
Rank: 1
等 级:新手上路
帖 子:45
专家分:0
注 册:2006-8-4
收藏
 问题点数:0 回复次数:5 
用筛法求素数的问题!

小弟写了一个用筛法求n以内的所有素数的程序,但是结果总是多了几个数,请各位帮忙看一下:
#include <stdio.h>
#define n 30

int main()
{
int i,j,k,s,a[n],b[n];
j=2;
for(i=0;i<n&&a[i]!=0;i++)//对数组进行初始化
{
if(j<=n)
{
a[i]=j;
j++;
}
else
{
a[i]=0;
j++;
}
b[i]=0;
}
for(i=0;a[i]!=0;i++)
{
for(j=i+1;a[j]!=0;j++)//把所有以a[i]为因子的数清零
{
if(a[j]%a[i]==0)
a[j]=0;
}

for(k=0,j=0;k<n;k++)//把不为零的数赋给数组b[]
{
if(a[k]!=0)
{
b[j]=a[k];
j++;
}
}
for(j=0;j<n;j++)//把数组b[]的值赋给a[]
a[j]=b[j];
}
printf("%d以内的所有素数有%d个分别是:\n",n,i);
for(i=0;a[i]!=0;i++)
printf("%4d",a[i]);
printf("\n");
return 0;
}

搜索更多相关主题的帖子: 筛法 素数 
2006-08-09 19:18
无心剑
Rank: 1
等 级:新手上路
帖 子:45
专家分:0
注 册:2006-8-4
收藏
得分:0 
没人理我!
不过我终于解决问题了
在把数组b[]的值赋给a[]后要对b[]清零
b[j]=0;
就可以了
呵呵
打扰大家了!
2006-08-09 19:34
soft_wind
Rank: 3Rank: 3
等 级:新手上路
威 望:8
帖 子:1430
专家分:0
注 册:2006-4-5
收藏
得分:0 

您的问题不止那个...
#include <stdio.h>
#define n 30

int main()
{
int i,j,k,s,a[n],b[n];
j=2;
for(i=0;i<n;i++)
{
a[i]=j++;
b[i]=0;
}
for(i=0;a[i]!=0;i++)
{
for(j=i+1;a[j]!=0;j++)
{
if(a[j]%a[i]==0)
a[j]=0;
}

for(k=0,j=0;k<n;k++)
{
if(a[k]!=0)
{
b[j]=a[k];
j++;
}
}
}
printf("%d以内的所有素数有%d个分别是:\n",n,j);
for(i=0;i<j;i++)
printf("%4d",b[i]);
printf("\n");
return 0;
}


对不礼貌的女生收钱......
2006-08-09 19:38
soft_wind
Rank: 3Rank: 3
等 级:新手上路
威 望:8
帖 子:1430
专家分:0
注 册:2006-4-5
收藏
得分:0 
首先,说下,我改的程序在输入里面是错的,我把您原来的else分支给删了,当时是为了查错方便。没记得改回来。
再说下您的错误。
1,既然用数组b[],后来的输出干吗又用a[]来输出。
2,for(;condition;)循环中的condition是用来说明循环进行的条件,您在两个for循环
for(i=0;i<n&&a[i]!=0;i++)
for(j=i+1;a[j]!=0;j++)
条件都不合适。

对不礼貌的女生收钱......
2006-08-09 19:58
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
以下是引用soft_wind在2006-8-9 19:38:39的发言:

您的问题不止那个...
#include <stdio.h>
#define n 30

int main()
{
int i,j,k,s,a[n],b[n];
j=2;
for(i=0;i<n;i++)
{
a[i]=j++;
b[i]=0;
}
for(i=0;a[i]!=0;i++)
{
for(j=i+1;a[j]!=0;j++)
{
if(a[j]%a[i]==0)
a[j]=0;
}

for(k=0,j=0;k<n;k++)
{
if(a[k]!=0)
{
b[j]=a[k];
j++;
}
}
}
printf("%d以内的所有素数有%d个分别是:\n",n,j);
for(i=0;i<j;i++)
printf("%4d",b[i]);
printf("\n");
return 0;
}

两个循环条件有点不对哦.如果碰到a[i]==0是否i后面的还要遍历呢.


倚天照海花无数,流水高山心自知。
2006-08-09 23:02
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 


#include <stdio.h>
#define n 30

int main()
{
int i,j,a[n];
j=2;
for(i=0;i<n-2;i++)
{
a[i]=j;
j++;
}
for(i=0;i<n-2;i++)
{
if(a[i]!=0)
{
for(j=i+1;j<n-2;j++)
{
if(a[j]!=0&&a[j]%a[i]==0)
a[j]=0;
}
}

}
printf("%d以内的所有素数有%d个分别是:\n",n,i);
for(i=0;i<n-2;i++)
{
if(a[i]!=0)
printf("%4d",a[i]);
}
printf("\n");
return(0);
}


倚天照海花无数,流水高山心自知。
2006-08-09 23:06
快速回复:用筛法求素数的问题!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.012643 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved