判别素数的一种方法

(一)

分析代码

研究对象为整数

1,如果输入0或负整数,输出"错误!你没有输入正整数"

2,如果输入1,输出"1既不是素数,也不是合数"

3,如果输入大于1的正整数,则进行判断,

a)如果该正整数被判定为合数,则输出

" 是合数"

b)如果该正整数被判定为素数,则输出

" 是素数"

(二)

素数的判定原则

对于大于1的正整数x进行判定,

x 对从2开始到x-1的正整数取余数,即x对 2,3,4,5,......,x-1  取余数得到若干余数

a_{2},a_{3},a_{4},a_{5},.....,a_{x-1}  

如果\forall i\epsilon(2,x-1) ,a_{i}\neq0,则x为素数

等价于

如果\prod{a_{i}} \neq 0(i from 2 to x-1),则x为素数

如果\exists i\epsilon(2,x-1), a_{i}=0,则x为合数

等价于

如果 \prod{a_{i} =0(i from 2 to x-1),则x为合数

(三)

实现代码

#include <iostream>

using namespace std;

int main()

{

    int a;

    cout << "输入一个正整数 :" << endl;

    cin >> a;

    if (a <=0) 
    {

        cout << "错误!你没有输入正整数" << endl;
        

    }
    if (a == 1)
    {

        cout << "1既不是素数,也不是合数" << endl;

    }

   if(a>1)
    {

        int  i;

        int  j;

        int  k;

        k = 1;

        for (i = 2; i < a; i++) 
        {

            j = a % i;

            k = k * j;

        }

        if (k == 0) 
        {

            cout << a << " 是合数" << endl;

        }

        else
        {

            cout << a << " 是素数 " << endl;

        }

    }

}
 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值