| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 461 人关注过本帖
标题:素数的一个小问题,求好方法,谢谢。
只看楼主 加入收藏
caynne
Rank: 1
等 级:新手上路
帖 子:8
专家分:1
注 册:2012-12-20
结帖率:66.67%
收藏
已结贴  问题点数:20 回复次数:2 
素数的一个小问题,求好方法,谢谢。
题目是这样的:从键盘输入正整数m和n,将m到n之间的所有素数存入数组s中,并将s中元素5个一行输出。

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


int find(int ,int ); //函数的功能是找出这个区间里面素数的个数

int main (void)
{
    int m , n;
    int k = 0;
        
    printf("输出你想求取的区间(m,n)中间空格隔开: ");
    scanf ("%d %d", &m,&n);

 
    int * s; 
     s = (int *)malloc(sizeof(int) * find(m,n));    //生成一个 存放 找到的 素数 的动态数组
    
    for(int i = m; i<n; i++)
    {
        for(int j = 2 ; j<i ; j++)
        {
            if( i % j == 0)
            {
                break;
            }
        }
        if(i == j)
        {
            *(s+k) = i;
            k++;
        }
    }

    for (int q = 0; q<find(m,n); q++)        //按每行五个输出,这个方法感觉丑死了,像一些有for语句
    {                                        //输出一些特定图形的方法感觉很神奇,就 是学不会~ TT
        printf("%d ", *(s+q));
        if((q+1) % 5 == 0 && q != 0)
        {
            printf("\n");
        }
    }
     
    return 0;
}

int find(int m, int n)
{
    int len = 0;
    for(int i = m; i<n; i++)
    {
        for(int j = 2 ; j<i ; j++)
        {
            if( i % j == 0)
            {
                break;
            }
        }
        if(i == j)
        {
            len ++;
        }
        
    }
    return len;
}
搜索更多相关主题的帖子: 正整数 
2013-03-30 23:12
caynne
Rank: 1
等 级:新手上路
帖 子:8
专家分:1
注 册:2012-12-20
收藏
得分:0 
谢谢啦,求好方法,求指教,感觉论坛的高手太多了,望其项背呀(可能连背都望不到啊!),啥时候能进步~~~~
2013-03-30 23:13
邓士林
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:淮河河畔
等 级:贵宾
威 望:61
帖 子:2392
专家分:13384
注 册:2013-3-3
收藏
得分:20 
#include <stdio.h>
#include <math.h>
int main()
{
    int m,n;
    int i,j,k=0;
    printf("请输入数值范围m--n:");
    scanf("%d%d",&m,&n);
    for(i=m;i<=n;i++)
    {
            if(i<=2)i++;
        for(j=2;j<i;j++)
        if(i%j==0)break;
            if(i==j)
            {
                k++;
                printf("%d ",i);
                if(k==5)printf("\n");
            }
    }
    return 0;
}应该可以

Maybe
2013-03-30 23:53
快速回复:素数的一个小问题,求好方法,谢谢。
数据加载中...
 
   



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

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