蓝桥杯(路径 动态规划 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;
}
相关推荐
帅_shuai_几秒前
UE Json 序列化和反序列化
c++·ue5·json·虚幻引擎
想唱rap2 分钟前
缓冲区的理解和实现
java·服务器·前端·c++·python
菩提祖师_7 分钟前
基于增量微调的大语言模型领域更新方法
c++·深度学习·ci/cd·云原生
小尧嵌入式20 分钟前
c++一致性哈希实现BST二叉树实现及相关知识
服务器·c语言·开发语言·c++·算法·链表·哈希算法
橘颂TA29 分钟前
【Linux】使用C++对线程进行封装
linux·开发语言·c++
有一个好名字31 分钟前
力扣-判断子序列
算法·leetcode·职场和发展
Q741_14732 分钟前
C++ 栈 模拟 力扣 946. 验证栈序列 每日一题 题解
c++·算法·leetcode·模拟·
微凉的衣柜36 分钟前
【3D 打印避坑实录】如何用 Blender 彻底修复空壳 STL
c++·3d·blender
敲代码敲到头发茂密37 分钟前
C++之运算符&循环
开发语言·c++
菩提祖师_42 分钟前
基于大数据的电力负荷预测与调度研究
java·开发语言·网络·c++·物联网