| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3651 人关注过本帖
标题:帮我完善一下。用筛法求出n以内的素数,n由键盘输入,用数组表示n个数的集合 ...
只看楼主 加入收藏
SZHLYJ
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2016-6-28
结帖率:0
收藏
已结贴  问题点数:20 回复次数:13 
帮我完善一下。用筛法求出n以内的素数,n由键盘输入,用数组表示n个数的集合。
#include<stdio.h>
#include<math.h>
#define N 100000000
void prime(int n);
int isPrime[N + 1];
int main()
{
    int i,n;
    scanf("%d", &n);
    prime(n);/*调用筛选素数函数*/
    for (i = 0; i <= n; i++)/*输出n以内的所有素数*/
    {
        if (isPrime[i] == 1)
            printf("%d\n", i);
    }
}
/*筛选从2到n之间的素数,筛选结果存入数组isPrime*/
void prime(int n)
{
    int i, j, m;
    for (i = 0; i <= n; i++)/*将isPrime数组元素初始化为1*/
        isPrime[i] = 1;
    isPrime[0] = isPrime[1] = 0;/*0和1不是素数,所以将相应的元素设置为0*/
    m = (int)sqrt(n);
    for (i = 2; i <= m; i++)
    {
        if (isPrime[i])/*筛选掉素数的整数倍*/
        {
            for (j = 2 * i; j <= n; j = j + i)
                isPrime[j] = 0;
        }
    }
}
搜索更多相关主题的帖子: include 键盘 元素 
2016-06-28 01:49
SZHLYJ
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2016-6-28
收藏
得分:0 
我写的程序只有输入比100000000小的数时才能顺利执行,我想改成无论输入什么数都可以执行,可以吗?
2016-06-28 01:51
SZHLYJ
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2016-6-28
收藏
得分:0 
各种方法都试了,一天无果,到现在还睡不着
2016-06-28 01:54
八画小子
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:37
帖 子:709
专家分:2063
注 册:2010-11-11
收藏
得分:10 
还在?稍后给你答案
2016-06-28 03:11
八画小子
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:37
帖 子:709
专家分:2063
注 册:2010-11-11
收藏
得分:0 
程序代码:
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#define N 100000000
void prime(int n);
//int isPrime[N + 1];
int * isPrime = NULL;
int main()
{
    int i,n;
    scanf("%d", &n);
    isPrime = malloc(sizeof(int) * (n + 1));
    prime(n);/*调用筛选素数函数*/
    for (i = 0; i <= n; i++)/*输出n以内的所有素数*/
    {
        if (isPrime[i] == 1)
            printf("%d\n", i);
    }
}
/*筛选从2到n之间的素数,筛选结果存入数组isPrime*/
void prime(int n)
{
    int i, j, m;
    for (i = 0; i <= n; i++)/*将isPrime数组元素初始化为1*/
        isPrime[i] = 1;
    isPrime[0] = isPrime[1] = 0;/*0和1不是素数,所以将相应的元素设置为0*/
    m = (int)sqrt(n);
    for (i = 2; i <= m; i++)
    {
        if (isPrime[i])/*筛选掉素数的整数倍*/
        {
            for (j = 2 * i; j <= n; j = j + i)
                isPrime[j] = 0;
        }
    }
} 
2016-06-28 03:12
八画小子
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:37
帖 子:709
专家分:2063
注 册:2010-11-11
收藏
得分:0 
没有验证你的计算素数的算法的正确性,仅仅把程序改成计算任意数范围的素数。这个任意数是有限定的,不得大于int类型的最大值。
2016-06-28 03:14
SZHLYJ
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2016-6-28
收藏
得分:0 
回复 6楼 八画小子
嗯嗯,我一会儿就试一下,那个程序的正确性昨天已经试过了,没问题,就是范围,谢谢你啦
2016-06-28 06:42
SZHLYJ
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2016-6-28
收藏
得分:0 
回复 5楼 八画小子
isPrime=malloc(sizeof(int)*(n+1));这一句提示;不能转换“void *”“int *”
2016-06-28 07:19
SZHLYJ
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2016-6-28
收藏
得分:0 
回复 5楼 八画小子
isPrime=(int*)malloc(sizeof(int)*(n+1));改成这样已经对啦  谢谢谢谢 万分感激
2016-06-28 07:24
linlulu001
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:20
帖 子:944
专家分:4047
注 册:2016-4-13
收藏
得分:10 
int类型改成unsigned long long类型。
unsigned long long取值范围为0到2^64-1,这个范围够你用了。
如果你要开辟一个2^64的空间,unsigned long long最大值是一个20位数,你的电脑开辟不出那么大的连续空间,也就是数组。如果想要存取数据,就改用文件来存取吧。
而5楼开辟空间又不检查空间是否开辟出来是不可取的。
2016-06-28 07:36
快速回复:帮我完善一下。用筛法求出n以内的素数,n由键盘输入,用数组表示n个数 ...
数据加载中...
 
   



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

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