| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 371 人关注过本帖
标题:素数问题
只看楼主 加入收藏
卡其
Rank: 2
等 级:论坛游民
帖 子:96
专家分:36
注 册:2010-8-30
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:4 
素数问题
程序代码:
#include<stdio.h>
#include<math.h>
#define N 101
main()
{
    int i,j,line,a[N];
    for(i=2;i<N;i++)
    {
        a[i]=i;
    }
    for(i=2;i<sqrt(N);i++)
    {
        for(j=i+1;j<N;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<N;i++)
    {
        if(a[i]!=0)
        {
            printf("%5d",a[i]);
            line++;
        }
        if(line==10)
        {
            printf("\n");
            line=0;
        }
    }
}
   for(i=2;i<sqrt(N);i++)
    {
        for(j=i+1;j<N;j++)
        {
            if(a[i]!=0&&a[j]!=0)
            if(a[j]%a[i]==0)
                a[j]=0;
        }
    }
帮忙解释下这几句。。。。还有那个sqrt(n)为什么不是100的开方而是101的开方?
2011-04-22 16:46
hnuhsg1226
Rank: 9Rank: 9Rank: 9
来 自:中国
等 级:蜘蛛侠
威 望:2
帖 子:314
专家分:1314
注 册:2011-3-27
收藏
得分:20 
首先解释为什么不是100,因为你写的是j<N,没有包含sqrt(N),如果加个等于,就可以写成100;
这句的意思是如果是素数,只能被1或者自身整除,如果被2,3....,j-1等等中一个数整除,那就不是素数,并将这个数赋值为0,如果不被其他数整除,保持原数不变。
因为每次都要从i+1开始,所以难免遇到不是素数已经置为0的数,用if(a[i]!=0&&a[j]!=0)做判断

我的地盘
2011-04-22 16:56
卡其
Rank: 2
等 级:论坛游民
帖 子:96
专家分:36
注 册:2010-8-30
收藏
得分:0 
谢啦。。。
2011-04-22 17:24
hnuhsg1226
Rank: 9Rank: 9Rank: 9
来 自:中国
等 级:蜘蛛侠
威 望:2
帖 子:314
专家分:1314
注 册:2011-3-27
收藏
得分:0 
没事,多交流

我的地盘
2011-04-22 17:45
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
问题解决的很快嘛

                                         
===========深入<----------------->浅出============
2011-04-22 17:51
快速回复:素数问题
数据加载中...
 
   



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

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