| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1356 人关注过本帖
标题:利用模块化思想,设计程序输出1到100 之间的素数对。
只看楼主 加入收藏
风行企鹅
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2017-5-31
结帖率:0
收藏
已结贴  问题点数:20 回复次数:5 
利用模块化思想,设计程序输出1到100 之间的素数对。
利用模块化思想,设计程序输出1到100 之间的素数对。所谓素数对是指相差为2 的两个素数。输出效果如下:
3 5
5 7
11 13
......

哪位大神会用vc写这个程序,急用,急用
求大神帮忙!!!
搜索更多相关主题的帖子: 设计程序 
2017-05-31 10:50
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:20 
方法有很多~可以先求所有素数求写素数对~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-05-31 12:30
风行企鹅
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2017-5-31
收藏
得分:0 
回复 2楼 九转星河
那劳烦大神写一个
2017-05-31 16:49
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
这个看时间吧~先要弄清楚模块化是什么~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-05-31 17:08
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
这里是欧拉筛法求100以内素数的代码~直接把之前自己写的Copy过来了~至于其它要求自己去完善一下~

程序代码:
#include<stdio.h>

#define MAX 100
char IsPrime[MAX+1]={0};
int prim[MAX+1]={0};

int main()
{
    int i=0;
    int j=0;
    int num=0;

    for (i=2;i<=MAX;++i)
    {
        if (!IsPrime[i])
            prim[num++]=i;

        for (j=0;j<num&&i*prim[j]<=MAX;++j)
        {
            IsPrime[i*prim[j]]=1;

            if (i%prim[j]==0)
                break;
        }
    }

    for (i=0;i<num;++i)
        printf("%-4d",prim[i]);

    puts("");

    return 0;
}

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-05-31 17:15
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
然后~改进一下就符合输出要求了~

当然模块化猜测应该是要调用函数实现的~改为用调用函数实现就可以了~~

程序代码:
#include<stdio.h>

#define MAX 100
char IsPrime[MAX+1]={0};
int prim[MAX+1]={0};

int main()
{
    int i=0;
    int j=0;
    int num=0;

    for (i=2;i<=MAX;++i)
    {
        if (!IsPrime[i])
            prim[num++]=i;

        for (j=0;j<num&&i*prim[j]<=MAX;++j)
        {
            IsPrime[i*prim[j]]=1;

            if (i%prim[j]==0)
                break;
        }
    }

    for (i=0;i<num-1;++i)
        if (prim[i+1]-prim[i]==2)
            printf("%-4d%-4d\n",prim[i],prim[i+1]);

    puts("");

    return 0;
}


[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-05-31 19:17
快速回复:利用模块化思想,设计程序输出1到100 之间的素数对。
数据加载中...
 
   



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

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