蓝桥杯(路径 动态规划 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;
}
相关推荐
想唱rap3 分钟前
传输层协议TCP
linux·运维·服务器·网络·c++·tcp/ip
香蕉鼠片17 分钟前
面试过程中被问懵
面试·职场和发展
瑶池酒剑仙32 分钟前
C++类和对象完全指南:从封装继承多态到内存布局的面向对象宝典(雨夜论道)
c语言·开发语言·c++·visual studio
潇湘散客1 小时前
CAX软件插件化设计实现牛刀小试
c++·算法·图形学·opengl
Ricky_Theseus1 小时前
const 和 #define 的区别
c++
WBluuue2 小时前
Codeforces 1094 Div1+2(ABCDE)
c++·算法
Languorous.2 小时前
C++智能指针详解:原理、使用及避坑指南
开发语言·c++
lingzhilab2 小时前
零知派ESP32-DFPlayer MP3智能音乐播放器2
c++·mfc
fan_music3 小时前
C语言如何实现C++的类
开发语言·c++
_君莫笑3 小时前
Qt+Qml前后端分离上位机软件技术方案
c++·qt·用户界面·qml