| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 24687 人关注过本帖
标题:用C++编写一个程序:输入一个数,并判断是否为素数
只看楼主 加入收藏
peterme
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2012-9-14
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:14 
用C++编写一个程序:输入一个数,并判断是否为素数
不知道怎么编写。希望有人能帮助
搜索更多相关主题的帖子: 希望 
2012-09-14 20:28
xufan
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:6
帖 子:232
专家分:804
注 册:2008-10-20
收藏
得分:0 
额...怎么回事呀,又是求素数!!!

~~~~~~我的明天我知道~~~。
2012-09-14 22:38
zhuanjia0
Rank: 4
等 级:业余侠客
威 望:3
帖 子:86
专家分:232
注 册:2012-1-13
收藏
得分:0 
我之前做过这样的一个题目,看完这些你就知道怎么做了

可以用两个循环,外层从2开始,内层也从2开始,在加一个if判断是否能整除
用筛法求1~1000之间的素数。
eratosthenes筛法:
1)    利用数组存放这1000个数;
2)    挖掉第一个数1(令该数=0);
3)    2没被挖掉,挖掉后面所有2的倍数;
4)    3没被挖掉,挖掉后面所有3的倍数;
5)    4被挖掉,不执行任何操作;
6)    5没被挖掉,挖掉后面所有5的倍数;
7)    ....直到最后一个数;
8)    剩下的非0数就是素数。

[ 本帖最后由 zhuanjia0 于 2012-9-15 11:53 编辑 ]
2012-09-15 11:50
peterme
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2012-9-14
收藏
得分:0 
回复 2楼 xufan
这是布置的一个实验啊。有点难的
2012-09-16 21:55
peterme
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2012-9-14
收藏
得分:0 
回复 3楼 zhuanjia0
只能用if语句来实现吗?能不能再具体点。
2012-09-16 22:01
zhaojigao
Rank: 2
等 级:论坛游民
威 望:1
帖 子:19
专家分:59
注 册:2012-9-6
收藏
得分:10 
# include<iostream>
# include<string>
# include<vector>
# include<math.h>
using namespace std;
int main()
{

    vector<long int> m;
    m.push_back(2);
    m.push_back(3);
    m.push_back(5);
    m.push_back(7);
    cout<<m[0]<<endl;
    cout<<m[1]<<endl;
    cout<<m[2]<<endl;
    cout<<m[3]<<endl;
    long int n=2;
    long int p=1;
    long int e=INT_MAX;
    int piaoshi=0;
    long int a=0;

    for(;a<200000;p++)
    {
         piaoshi=0;
        //cout<<"开始找";
        a=p*10+1;
        long int b=sqrt(a);
            if(m[n]<=b)
                n++;
        for(int c=0;c<n;c++)
        {
            long int x;
            long int y;
            y=m[c];
            x=a%y;
        if(x==0)
        {
            piaoshi=1;
            break;
        }
        }
     if(piaoshi==0)
     {
         m.push_back(a);
         cout<<a<<endl;
         //piaoshi=1;
     }
    else
        piaoshi=0;
         a=p*10+3;
         b=sqrt(a);
        if(m[n]<=b)
            n++;
        for(int cc=0;cc<n;cc++)
        {
        
            long int x;
            long int y;
            y=m[cc];
            x=a%y;
          if(x==0)
          {
            piaoshi=1;
            break;
          }
        }
     if(piaoshi==0)
     {
         m.push_back(a);
         cout<<a<<endl;
        
     }
     else  
         piaoshi=0;
         
         a=p*10+7;
         b=sqrt(a);
         if(m[n]<=b)
            n++;
        for(int ccc=0;ccc<n;ccc++)
        {
        
            long int x;
            long int y;
            y=m[ccc];
            x=a%y;
        if(x==0)
        {
            piaoshi=1;
            break;
        }
        }
         if(piaoshi==0)
         {
         m.push_back(a);
         cout<<a<<endl;
        
         }
         else
              piaoshi=0;
        
          a=p*10+9;
         b=sqrt(a);
         if(m[n]<=b)
            n++;
        for(int cccc=0;cccc<n;cccc++)
        {
        
            long int x;
            long int y;
            y=m[cccc];
            x=a%y;
        if(x==0)
        {
            piaoshi=1;
            break;
        }
        }
       if(piaoshi==0)
       {
         m.push_back(a);
         cout<<a<<endl;
         
        }
       else
           piaoshi=0;
}


    return 0;
}
2012-09-17 10:56
dz789989
Rank: 2
等 级:论坛游民
威 望:1
帖 子:44
专家分:95
注 册:2012-8-21
收藏
得分:10 
程序代码:
#include<iostream.h>
void main()
{
    int i,j,n;
    int flag=0;
    cin>>n;
    if(n<=0)
        cout<<"输入错误!";
    else
    {
        if(n==1)
            cout<<"不是素数!";
        else
        {
            for(i=2;i<n;i++)
            {
                j=n%i;
                if(j==0)
                {
                    flag=1;
                    break;
                }
            }
            if(flag==0)
                cout<<"是素数!";
            else
                cout<<"不是素数!";
        }
    }
    cout<<endl;
}
网上拉的代码
2012-09-17 21:15
pangding
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:北京
等 级:贵宾
威 望:94
帖 子:6784
专家分:16751
注 册:2008-12-20
收藏
得分:0 
求素数的帖子真多呀。素数的概念应该是小学学的吧,还能有多复杂。如果忘了基本结果,百度一下也不难找到。
其实这类题都是练习简单的基本运算和分支逻辑的。楼主应该自己好好想想怎么写。
2012-09-18 19:02
qunxingw
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:24
帖 子:1676
专家分:7295
注 册:2011-6-30
收藏
得分:0 
素数,皇后,排序难绕开的思考题材

www.qunxingw.wang
2012-09-19 11:00
lwbkfc
Rank: 2
等 级:论坛游民
威 望:1
帖 子:13
专家分:17
注 册:2012-9-24
收藏
得分:0 
#include<iostream>
using namespace std;
bool fun(int n)
{
    bool pan=true;
    for(int i=2;i<=sqrt(float(n));i++)
    {
        if(n%i==0)
        {
            pan=false;
            break;
        }
    }
    return pan;
}
int main()
{
    int n;
    cout<<"input n:";
    cin>>n;
    if(fun(n))
    {
        cout<<"yes"<<endl;
    }
    else
        cout<<"no"<<endl;
}
2012-09-25 09:47
快速回复:用C++编写一个程序:输入一个数,并判断是否为素数
数据加载中...
 
   



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

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