蓝桥杯(路径 动态规划 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;
}
相关推荐
-Rane6 分钟前
【C++】内存管理
开发语言·c++
水饺编程15 分钟前
第4章,[标签 Win32] :绘制信息结构
c语言·c++·windows·visual studio
WBluuue19 分钟前
AtCoder Beginner Contest 441(ABCDEF)
c++·算法
晨非辰22 分钟前
C++波澜壮阔40年|类和对象篇:拷贝构造与赋值重载的演进与实现
运维·开发语言·c++·人工智能·后端·python·深度学习
hetao173383727 分钟前
2026-01-16~19 hetao1733837 的刷题笔记
c++·笔记·算法
玖釉-34 分钟前
[Vulkan 学习之路] 29 - 加载模型 (Loading Models)
c++·windows·图形渲染
天真小巫42 分钟前
2026.1.19总结
职场和发展
HelloWorld1024!1 小时前
C++中链表的虚拟头结点:应用场景与使用时机
网络·c++·链表
fakerth1 小时前
【C++】【Linux】从零实现日志库:LogLib 设计与实现详解
c++·日志库
大闲在人1 小时前
Trae builder 实战: 让 C++ 函数像 Python 一样返回多个值
c++·python·ai编程