蓝桥杯(路径 动态规划 C++)

思路:

1、利用动态规划的思想。

2、用f[i]来记录从第一个点到第i个点的最短距离。

3、f[i]赋值分两种情况,第一种:f[i]为0的时候,也就是第一种刚到i点的情况,记录其距离为最小公倍数;第二种:f[i]已经有值了,比较新的点到其距离和之前点到其距离,取小的赋值。

4、最后输出f[2021]就是第一个点到第2021个点的最短距离。

cpp 复制代码
#include<iostream>
using namespace std;
int gcd(int x, int y)//辗转相除法,求最大公约数
{
	return !y ? x : gcd(y, x % y);
}
int main()
{
	int f[2030]={0};//记录到该点的最短距离
	for(int i=1;i<=2021;i++)
		for (int j = i + 1; j <= i + 21; j++)
		{
			if (j > 2021)
				break;
			if (f[j] == 0)
				f[j] = f[i] + i * j / gcd(i, j);
			else
				f[j] = min(f[j], f[i] + i * j / gcd(i, j));
		}
	cout << f[2021] << endl;
}
相关推荐
阿Y加油吧13 分钟前
二刷 LeetCode:两道经典贪心题复盘
算法·leetcode·职场和发展
CSCN新手听安17 分钟前
【Qt】Qt窗口(五)QDialog对话框的使用,点击按钮弹出新的对话框,自定义对话框界面,模态对话框model
开发语言·c++·qt
计算机魔术师20 分钟前
【职场观察 | 技术人处境】五一假期结束,职场两边同时加速——“简历热“和“优化潮“背后的结构性逻辑
人工智能·面试·职场和发展·cot 推理·技术人求职·ai替代逻辑
晴夏。20 分钟前
c++调用lua的方法
c++·游戏引擎·lua·ue
Lhan.zzZ8 小时前
笔记_2026.4.28_004
c++·ide·笔记·qt
wuminyu10 小时前
专家视角看Java字节码加载与存储指令机制
java·linux·c语言·jvm·c++
木喃的井盖10 小时前
无锁队列细节
c++·工程
王老师青少年编程10 小时前
csp信奥赛C++高频考点专项训练之字符串 --【字符串基础】:输出亲朋字符串
c++·字符串·csp·高频考点·信奥赛·专项训练·输出亲朋字符串
WBluuue11 小时前
数据结构与算法:莫队(一):普通莫队与带修莫队
c++·算法
KuaCpp12 小时前
C++面向对象(速过复习版)
开发语言·c++