蓝桥杯(路径 动态规划 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;
}
相关推荐
cany10007 小时前
C++ - 智能指针
开发语言·c++
EnCi Zheng7 小时前
S10-蓝桥杯 17822 乐乐的积木塔
职场和发展·蓝桥杯
Emberone7 小时前
深入理解 C++ STL string:从接口使用到底层模拟实现
c++·stl
t***5448 小时前
如何在 Dev-C++ 中设置和使用 Clang 编译器
开发语言·c++
楼田莉子8 小时前
CMake学习:CMake语法
c++·后端·学习·软件构建
无限进步_8 小时前
C++ 继承机制完全解析:从基础原理到菱形继承问题
java·开发语言·数据结构·c++·vscode·后端·算法
盐焗鹌鹑蛋8 小时前
【C++】vector类
c++
jf加菲猫9 小时前
第15章 文件和目录
开发语言·c++·qt·ui
思麟呀9 小时前
Select多路转接
linux·网络·c++·网络协议·http
aq55356009 小时前
开源吐槽大会:让技术痛点变笑点
c++·mfc