当前位置:   article > 正文

基础算法汇总_c++算法汇总

c++算法汇总

1. 素数

bool isPrime(int x){
	if(x==1)return false;
	if(x==2)return true;
	for(int i=2;i<x;++i){
		if(x%i==0)return false;
		
	}
	return true;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

2. 打印小于n的所有素数

import java.util.Scanner;

public class E {
	public static void main(String[] args) {
		Scanner scan=new Scanner(System.in);
		int n;
		n=scan.nextInt();
		long[] isPrime=new long[n];
		for(int i=2;i<n;++i) {
			if(i==2) {
				for(int k=i*i;k<n;k+=i)isPrime[k]=1;
				continue;
			}
			boolean sign=true;
			if(isPrime[i]==1)continue;
			for(int j=2;j<Math.sqrt(j);++j) {
				if(i%j==0) {
					sign=false;break;
				}
			}
			if(sign) {
				if(i<Math.sqrt(n))
				for(long k=i*i;k<n;k+=i)isPrime[(int)k]=1;
			}
			
			
		}
		for(int i=2;i<n;++i) {
			if(isPrime[i]==0)
				System.out.println(i);
		}

	}
}

  • 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
  • 31
  • 32
  • 33
  • 34
  • 35
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/920663
推荐阅读
相关标签
  

闽ICP备14008679号