蓝桥杯(路径 动态规划 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;
}
相关推荐
(●—●)橘子……8 小时前
力扣第503场周赛练习理解
python·学习·算法·leetcode·职场和发展·周赛
feng_you_ying_li10 小时前
C++复习二,继承与多态
c++
小小de风呀10 小时前
de风——【从零开始学C++】(十一):list的基本使用和模拟实现
开发语言·c++·list
陌路2011 小时前
C++高级进阶--夯实进阶基础(1)
开发语言·c++
郝学胜-神的一滴12 小时前
中级OpenGL教程 008:精准控制高光光斑大小与强度
c++·unity·godot·three.js·图形学·opengl·unreal
浮午12 小时前
字节AI Agent开发面试全解析:15道高频问题+深度答案
人工智能·面试·职场和发展
牢姐与蒯12 小时前
c++数据结构之c++11(一)
数据结构·c++
折戟不必沉沙13 小时前
构造和析构函数能否是虚函数?能否调用虚函数?
c++
-To be number.wan13 小时前
算法日记 | STL- sort排序
c++·算法
不想写代码的星星13 小时前
编译期策略模式:当模板成为策略容器
c++