普通方法求素数与筛法求素数比較

20150806

package day06;

/*
 * 普通方法求素数与筛法求素数比較
 */
import java.util.*;

public class TestSushu {

	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		System.out.print("查找范围2~");
		int n = scan.nextInt();

		long s1=System.currentTimeMillis();
		//1--普通方法求素数
		int count1 = 0;
		for(int i=2,j=0;i<=n;i++){
			int temp=(int)(Math.sqrt(i));
			for(j=2;j<=temp;j++){
				if(i%j==0){
					break;
				}
			}
			if(j>temp){
				//System.out.print(i+"\t");
				count1 ++;
				if(count1%15==0){
					//System.out.println();
				}
			}
		}
		System.out.println("\n"+"2~"+n+"共同拥有"+count1+"个素数");
		long e1=System.currentTimeMillis();
		System.out.println("time1="+(e1-s1));
		System.out.println("******************");

		long s2=System.currentTimeMillis();
		//2--筛法求素数
		boolean[] b = new boolean[n+1];
		b[0]=b[1]=true;
		for(int i=2;i<b.length;i++){
			if(!b[i]){
				for(int j=i*2;j<b.length;j+=i){
					b[j]=true;
				}
			}
		}
		int count2 = 0;
		for(int i=2;i<b.length;i++){
			if(!b[i]){
				//System.out.print(i+"\t");
				count2++;
				if(count2%15==0){
					//System.out.println();
				}
			}
		}
		System.out.println("\n"+"2~"+n+"共同拥有"+count2+"个素数");
		long e2=System.currentTimeMillis();
		System.out.println("time2="+(e2-s2));

	}

}

筛法求素数原理:

总结:筛法求素数速度更快,尤其是数据比較大的时候

时间: 2024-10-07 14:29:35

普通方法求素数与筛法求素数比較的相关文章

普通方法求素数与筛法求素数比较

20150806 package day06; /* * 普通方法求素数与筛法求素数比较 */ import java.util.*; public class TestSushu { public static void main(String[] args) { Scanner scan = new Scanner(System.in); System.out.print("查找范围2-"); int n = scan.nextInt(); long s1=System.curre

素数相关?(有关素数的题持续更新中)x

素数(大体举几个栗子): 素数相关知识: 素数概念: 最大公约数只有1和它本身的数叫做质数(素数) 素数小性质: 1.大于一的整数必有素因数. 2.设p是素数,n是任意一个整数 能够推出p|n,(p,n)=1; 3.设p是素数,a,b为整数,若p|ab,则ab中至少有一个能被p整除 4.素数有无穷多个证明: (素数与整数之间的关系:1整除2互素) 假定正整数中只有有限个素数 设p1,p2……pk为从小到大排列起来的数 且N=p1*p2*……pk 设M=N+1 如果M为素数,那么M要大于p1,p2

Algorithm --&gt; 筛法求素数

一般的线性筛法 genPrime和genPrime2是筛法求素数的两种实现,一个思路,表示方法不同而已. #include<iostream> #include<math.h> #include<stdlib.h> using namespace std; const int MAXV = 100; //素数表范围 bool flag[MAXV+1]; //标志一个数是否为素数 int prime[MAXV+1]; //素数表,下标从0开始 int size=0; //

POJ2739_Sum of Consecutive Prime Numbers【筛法求素数】【枚举】

Sum of Consecutive Prime Numbers Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 19350 Accepted: 10619 Description Some positive integers can be represented by a sum of one or more consecutive prime numbers. How many such representations d

筛法求素数

筛法求素数,寻找素数最经典快速的方法!!! 用筛法求素数的基本思想是: 把从1开始的.某一范围内的正整数从小到大顺序排列, 1不是素数,首先把它筛掉.剩下的数中选择最小的数是素数,然后去掉它的倍数.依次类推,直到筛子为空时结束.如有: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 1不是素数,去掉.剩下的数中2最小,是素数,去掉2的倍数,余下的数是: 3 5 7 9 11 13 1

uva 10375 唯一分解定理 筛法求素数【数论】

唯一分解理论的基本内容: 任意一个大于1的正整数都能表示成若干个质数的乘积,且表示的方法是唯一的.换句话说,一个数能被唯一地分解成质因数的乘积.因此这个定理又叫做唯一分解定理. 举个栗子:50=(2^1)*(5^2) 题目一般的思路就是要把素数表打出来,eg上面的例子 e={1,0,2,0,0......} 下面是两个题目,仅说说大致的思想: 题目一: E=(X1*X3*X4* ...*Xk)/X2   判断E是不是整数 如果把(X1*X3*X4* ...*Xk)分解成素数相乘,将X2也分解成素

一般筛法求素数+快速线性筛法求素数

素数总是一个比较常涉及到的内容,掌握求素数的方法是一项基本功. 基本原则就是题目如果只需要判断少量数字是否为素数,直接枚举因子2 ..N^(0.5) ,看看能否整除N. 如果需要判断的次数较多,则先用下面介绍的办法预处理. 一般的线性筛法 首先先介绍一般的线性筛法求素数 void make_prime() { memset(prime, 1, sizeof(prime)); prime[0]=false; prime[1]=false; int N=31700; for (int i=2; i<

孪生素数(用筛法求素数)

所谓孪生素数指的就是间隔为 2 的相邻素数,它们之间的距离已经近得不能再近了, 就象孪生兄弟一样.最小的孪生素数是 (3, 5), 在 100 以内的孪生素数还有 (5, 7), (11, 13), (17, 19), (29, 31), (41, 43), (59, 61) 和 (71, 73),总计有 8 组. 但是随着数字的增大,孪生素数的分布变得越来越稀疏,寻找孪生素数也变得越来越困难. 那么会不会在超过某个界限之后就再也不存在孪生素数了呢? 孪生素数有无穷多对!这个猜想被称为孪生素数猜

POJ 2689 - Prime Distance - [筛法求素数]

题目链接:http://poj.org/problem?id=2689 Time Limit: 1000MS Memory Limit: 65536K Description The branch of mathematics called number theory is about properties of numbers. One of the areas that has captured the interest of number theoreticians for thousan