思路:欧几里得算法
【欧几里得演算法(辗转相除法)】 https://www.bilibili.com/video/BV19r4y127fu/?share_source=copy_web&vd_source=d124eda224bf54d0e3ab795c0b89dbb0
- 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开始,除了1和它本身之外没有能整除它的数
合数是指2开始,除了1和它本身之外有能整除它的数
思路:第一种循环暴力
- class Solution {
- public int countPrimes(int n) {
- int count = 0;
- if(n>2){
- count++;
- }else{
- return 0;
- }
- for(int i = 3;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开始
- class Solution {
- public int countPrimes(int n) {
- int count = 0;
- int[] nums = new int[n];
- for(int i = 2;i
- if(nums[i] == 0){
- count++;
- if((long) i*i
- for(int j = i*i;j
- nums[j] = 1;
- }
- }
- }
- }
- return count;
- }
- }
3.丑数
思路:可以知道一个数是丑数那么,n = 2^a+3^b+5^c成立
- 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;
- }
- }
- }
-
相关阅读:
【JAVA】浅解线程池ThreadPoolExecutor的各个参数
java基于ssm的家教课程管理系统
docker save 命令 docker load 命令 快速复制容器
第三章:form表单
power point导出pdf保留字体
makefile的基础使用
方舟生存进化游戏设置怎么调设置推荐
从源码角度看React-Hydrate原理
微信小程序获取手机号phonenumber.getPhoneNumber接口开发
uni-app:canvas-图形实现1
-
原文地址:https://blog.csdn.net/Candy___i/article/details/132888237