蓝桥杯(路径 动态规划 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;
}
相关推荐
老王熬夜敲代码13 分钟前
C++模版元编程2
开发语言·c++
hope_wisdom22 分钟前
C/C++数据结构之队列基础
c语言·数据结构·c++·队列·queue
图形学爱好者_Wu23 分钟前
C++ 数据结构 | 数组的底层原理
c++
阿猿收手吧!41 分钟前
【C++】brpc与grpc对比
开发语言·c++
oioihoii1 小时前
C++虚函数表与多重继承内存布局深度剖析
java·jvm·c++
BestOrNothing_20151 小时前
C++ 内存泄漏的“真实成本”: 内存单位换算、堆分配开销与工程级判断
c++·内存管理·内存泄漏·堆内存·raii·内存换算·异常安全
WBluuue2 小时前
Codeforces Global 31 Div1+2(ABCD)
c++·算法
zmzb01032 小时前
C++课后习题训练记录Day58
开发语言·c++
Sunsets_Red2 小时前
待修改莫队与普通莫队优化
java·c++·python·学习·算法·数学建模·c#
爱学习的梵高先生2 小时前
C++:友元
开发语言·c++