Mersenne素数

Mersenne素数

如果一个素数可以写成2^p-1的形式,那么该素数就称为Mersenne素数,其中p是一个正整数。编写程序找出p<=100的所有Mersenne素数,然后显示如下输出。图片中的输出数据并不完整(数据太大,程序要运行几个小时,就不弄全图啦)。

在这里插入图片描述
下面是代码:

package java实验1019;
import java.math.BigInteger;
public class java_1019 {

	/**
	 * @param args
	 */
	final static int s=2;//定义常量,便于算式中a^p-1的a的修改
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		BigInteger a=BigInteger.valueOf(s);//定义一个数值为2的BigInteger对象
		BigInteger b=BigInteger.valueOf(s);
		BigInteger c=new BigInteger("1");
		System.out.println("p\t\t2^p-1");
		for(int i=1;i<=100;)
		{
			if(i==1)//由于1和2均不是素数,所以从3开始;p=2时,a=3
			{
			a=a.multiply(b).subtract(c);//a=a*2-1;
			}
			else
			{
				a=a.add(c).multiply(b).subtract(c);//a=(a+1)*2-1
			}
			i++;
			if(素数(a)==true)
				{
				System.out.println(i+"\t\t"+a);
				}
		}

	}
	private static BigInteger BigInteger(String string) {
		// TODO Auto-generated method stub
		return null;
	}
	public static boolean 素数(BigInteger a)
	{
		int j=2;
		BigInteger i=BigInteger.valueOf(j);
		BigInteger s=new BigInteger("0");
		BigInteger b=new BigInteger("1");
		while(i.compareTo(a)<0)//从2开始计算,如果a的数值能整除i的数值,就不是素数
		{
			if(a.remainder(i).compareTo(s)==0)//BigInteger.remainder()计算余数
			{
				return false;
			}
			i=i.add(b);//i=i+1;
		}
		return true;
		
	}
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值