P593 既约分数

这个题本质就是在0-2020寻找最大公约数是1的两个数

求两个数最大公约数要用到欧几里得算法

欧几里得算法:

两个数的最大公约数 = 较小的数 % (较大的数 除以 较小的数 的余数),一直除,直到最后余数为0,最后那个余数就是最大公约数

举例:

求24和18的最大公约数:

24除以18 = 1...6 18除以6 = 3....0 所以最大公约数是6

求48和18的最大公约数:

48除以18 = 2...12 18除以12 = 1...6 12除以6 = 2...0 所以最大公约数是6

其中运用到了辗转相除法:

1,大的数除以小的数

2,得到余数

3,把原来的小数当作新的大数,把余数当作新的小数

4,重复除

5,直到余数 = 0 ,最后的除数就是答案

代码奉上:

java 复制代码
public class Main {
    public static void main(String[] args)  {
       int mol = 0;//分子
       int den = 0;//分母
        int res = 0;//最终找到的个数

        for(int i = 1 ; i <= 2020 ; i++){//找分子
            for(int j = 1 ; j <= 2020 ; j++){//找分母
                if(getGCD(i,j) == 1){
                    res++;
                }

            }

        }
        System.out.println(res);
    }
    public static int getGCD(int a ,int b){//欧几里得算法找最大公约数
        a = Math.abs(a);
        b = Math.abs(b);
            while( b != 0){
                int temp = b;
                b = a % b;//让b成为余数,余数成为下一个新的小数
                a = temp;//让较小的数,也就是原先的变成新的大数
            }
            return a;
    }
}

注意,欧几里得算法不需要判断两个数哪个大,直接进行取模运算就能够自动处理

举例:

18和24:

18%24=18 --> 24%18

相关推荐
Das18 小时前
图像色彩迁移技术算法及基本原理
算法
发疯幼稚鬼8 小时前
二叉树的广度优先遍历
c语言·数据结构·算法·宽度优先
谭欣辰8 小时前
C++ DFS 与 BFS 剪枝方法详解
c++·算法·剪枝
c++之路8 小时前
C++ 预处理器
开发语言·c++
fengxin_rou9 小时前
RabbitMQ安装教程:windows本地安装和docker部署
java·分布式·后端·rabbitmq
Via_Neo9 小时前
乘积最大问题
数据结构·算法
a8a3029 小时前
Laravel7.x核心特性全解析
java·spring boot·后端
CN-Dust9 小时前
【C++专题】格式化输出与输入
开发语言·c++·算法
AI人工智能+电脑小能手9 小时前
【大白话说Java面试题】【Java基础篇】第19题:HashMap的key如何减少发生哈希冲突
java·开发语言·后端·面试·哈希算法·hash-index·hash
coderlin_9 小时前
Langgraph项目三 agent搭建
java·数据库·redis