天天看點

Mersenne素數

Mersenne素數

如果一個素數可以寫成2^p-1的形式,那麼該素數就稱為Mersenne素數,其中p是一個正整數。編寫程式找出p<=100的所有Mersenne素數,然後顯示如下輸出。圖檔中的輸出資料并不完整(資料太大,程式要運作幾個小時,就不弄全圖啦)。

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;
		
	}
}