蓝桥杯(路径 动态规划 C++)

思路:

1、利用动态规划的思想。

2、用fi来记录从第一个点到第i个点的最短距离。

3、fi赋值分两种情况,第一种:fi为0的时候,也就是第一种刚到i点的情况,记录其距离为最小公倍数;第二种:fi已经有值了,比较新的点到其距离和之前点到其距离,取小的赋值。

4、最后输出f2021就是第一个点到第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;
}
相关推荐
回眸&啤酒鸭6 分钟前
【回眸】低压电工证培训记录
职场和发展
Shadow(⊙o⊙)17 分钟前
QT常用控件1.0,enabled() geometry() QIcon的.qrc文件导入
开发语言·c++·qt
wuminyu21 分钟前
Java锁膨胀机制之偏向锁到轻量级锁源码剖析
java·linux·c语言·jvm·c++
葱卤山猪28 分钟前
二进制字节流序列化
c++·序列化
Lazionr28 分钟前
类和对象(中):对象生命周期与运算符重载
c++
凡人叶枫31 分钟前
Effective C++ 条款13:以对象管理资源(RAII)
java·linux·开发语言·c++·嵌入式开发
风筝在晴天搁浅36 分钟前
LeetCode CodeTop 88.合并两个有序数组
算法·leetcode·职场和发展
星恒随风37 分钟前
C++ 类和对象入门(六):友元、内部类、匿名对象和编译器优化
开发语言·c++·笔记·学习·状态模式
Irissgwe42 分钟前
C++ STL 详解:stack 和 queue 的介绍使用与模拟实现
c++·stl·queue·stack
油炸自行车44 分钟前
【bug】Qt 6 Q_NAMESPACE 跨 DLL 链接错误:LNK2019 无法解析 staticMetaObject
数据库·c++·qt·bug·link2019·q_namespace_exp·namespaceexport