1.欧几里得算法
思路:欧几里得算法
【欧几里得演算法(辗转相除法)】 https://www.bilibili.com/video/BV19r4y127fu/?share_source=copy_web\&vd_source=d124eda224bf54d0e3ab795c0b89dbb0
java
class Solution {
public int findGCD(int[] nums) {
int min = Integer.MAX_VALUE, max = Integer.MIN_VALUE;
for (int num : nums) {
if (num > max) {
max = num;
}
if (num < min) {
min = num;
}
}
return gcd(max,min);
}
public int gcd(int a, int b) {
return b == 0 ? a : gcd(b,a%b);
}
}
2.素数和合数
素数是指2开始,除了1和它本身之外没有能整除它的数
合数是指2开始,除了1和它本身之外有能整除它的数
1)计数质数
思路:第一种循环暴力
java
class Solution {
public int countPrimes(int n) {
int count = 0;
if(n>2){
count++;
}else{
return 0;
}
for(int i = 3;i<n;i++){
if(isPrime(i)){
count++;
}
}
return count;
}
public boolean isPrime(int n){
double N = Math.sqrt(n);
for(int i = 2;i<=N;i++){
if(n%i == 0){
return false;
}
}
return true;
}
}
2)埃氏筛
当确定一个数为素数则它的n倍数都不是素数
注意的是每次筛选从i*i开始,因为这是最小的未被筛选过的,例如3开始筛选3的1,2,3,4,5...倍数都被筛选过了,那么5开始筛选就得从5*5开始
java
class Solution {
public int countPrimes(int n) {
int count = 0;
int[] nums = new int[n];
for(int i = 2;i<n;i++){
if(nums[i] == 0){
count++;
if((long) i*i<n){
for(int j = i*i;j<n;j += i){
nums[j] = 1;
}
}
}
}
return count;
}
}
3.丑数
思路:可以知道一个数是丑数那么,n = 2^a+3^b+5^c成立
java
class Solution {
public boolean isUgly(int n) {
if(n == 0){
return false;
}
int[] elements = {2,3,5};
for(int e : elements){
while(n%e == 0){
n = n/e;
}
}
if(n == 1){
return true;
}else{
return false;
}
}
}