蓝桥杯(路径 动态规划 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;
}
相关推荐
游戏23人生2 分钟前
c++ 语言教程——16面向对象设计模式(五)
开发语言·c++·设计模式
老王熬夜敲代码4 分钟前
C++的decltype
开发语言·c++·笔记
闻缺陷则喜何志丹12 分钟前
【C++组合数学】P8106 [Cnoi2021] 数学练习|普及+
c++·数学·洛谷·组合数学
ALex_zry16 分钟前
C++ const成员函数详解:原理、应用与最佳实践
c++
hetao17338371 小时前
2025-12-22 hetao1733837的笔记
c++·笔记·算法
charlee441 小时前
一种基于 SQLite3 的半自动 C++ ORM 实现
c++·sql·sqlite·orm·crud
DeltaTime1 小时前
三 视图变换, 投影变换, 正交投影, 透视投影
c++·图形渲染
superman超哥1 小时前
仓颉Result类型的错误处理模式深度解析
c语言·开发语言·c++·python·仓颉
八月的雨季 最後的冰吻1 小时前
FFmepg-- 38-ffplay源码-缓冲区 audio_buf调试
c++·ffmpeg·音视频
会思考的猴子1 小时前
UE5 C++ 笔记 GameplayAbilitySystem人物角色
c++·笔记·ue5