P1460 路径问题

这道题实际上是动态规划

先看代码:

java 复制代码
import java.util.Arrays;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        int n = 2022;
        int[] q = new int[n];
        q[1] = 0;
        for(int i = 2 ; i <= 2021 ; i++) {
            q[i] = Integer.MAX_VALUE;
        }
        for(int i = 1 ; i <= 2020 ; i++){
            for(int j = i+1 ; j <= 2021 && (j-i <=21) ; j++){
                q[j] = Math.min(q[j] , q[i] + lcm(i,j));
                }
            }
        System.out.println(q[2021]);
        }

    public static int gcd(int a , int b){
        a = Math.abs(a);
        b = Math.abs(b);
        while(b != 0){
            int temp = b;
            b = a % b;
            a = temp;
        }
        return a;
    }
    public static int lcm(int a , int b){
        int res = 0;
        if(a==0 || b==0){
            return res=0;
        }else{
            return res = Math.abs(a * b)/gcd(a,b);
        }
    }

}

分段解释:

这是主函数,第一个for循环的意思是初始化:

从1走到1的消耗是0,从1到别的地方都走不到

此处双重循环:

第一个for循环的含义是 我现在站在i点的位置

第二个for循环的含义是 我能走到 i+1 i+2 i+3 ....最大i+21的位置

只要原来的路贵,就换新路

gcd方法是求最大公因数

也可以这么写:

java 复制代码
    public static int gcd(int a, int b) {
        return b != 0 ? gcd(b, a % b) : a;
    }

返回的是一个三目运算符:

如果b != 0,那么就递归调用gcd(b,a%b),把b作为第一个参数,把a%b作为第二个参数

如过b = 0,那么就返回a

lcm方法是求最小公倍数

a b的最小公倍数就是其乘积的绝对值 除以 他们的最大公因数

相关推荐
运维行者_8 小时前
云计算连接性与互操作性
服务器·开发语言·网络·web安全·网络基础设施
郝学胜-神的一滴8 小时前
Qt 高级开发 010: 从跨界面传值到自定义信号
开发语言·c++·qt·程序人生·用户界面
社交怪人8 小时前
【浮点数相除的余】信息学奥赛一本通C语言解法(题号1029)
c语言·开发语言
无关86888 小时前
Spring Boot 项目标准化部署打包实战
java·spring boot·后端
jay神8 小时前
基于微信小程序课外创新实践学分认定系统
java·spring boot·小程序·vue·毕业设计
努力弹琴的大风天8 小时前
如何用AI开发matlab/Simulink工具栏模块,实现相关的功能
开发语言·人工智能·matlab
小白学大数据8 小时前
Scrapling:极简高效的 Python 智能爬虫框架
开发语言·爬虫·python·数据分析
天下无敌笨笨熊8 小时前
C#常用三方库使用心得
开发语言·c#
basketball6168 小时前
C++ 继承完全指南:从 is-a 关系到虚继承的底层真相
开发语言·c++
Gauss松鼠会8 小时前
GaussDB(DWS) GUC参数修改、查看
java·数据库·sql·数据库开发·gaussdb