蓝桥杯(路径 动态规划 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;
}
相关推荐
一只小小的芙厨20 分钟前
寒假集训笔记·树上背包
c++·笔记·算法·动态规划
以卿a30 分钟前
C++(继承)
开发语言·c++·算法
czxyvX1 小时前
017-AVL树(C++实现)
开发语言·数据结构·c++
你真是饿了1 小时前
1.C++入门基础
开发语言·c++
elseif1231 小时前
【C++】并查集&家谱树
开发语言·数据结构·c++·算法·图论
凯子坚持 c1 小时前
C++基于微服务脚手架的视频点播系统---客户端(4)
数据库·c++·微服务
问好眼2 小时前
【信息学奥赛一本通】1275:【例9.19】乘积最大
c++·算法·动态规划·信息学奥赛
coder攻城狮2 小时前
VTK系列1:在屏幕绘制多边形
c++·3d
学历真的很重要2 小时前
【系统架构师】第二章 操作系统知识 - 第二部分:进程管理(详解版)
学习·职场和发展·系统架构·系统架构师
HAPPY酷2 小时前
构造与析构:C++ 中对象的温柔生灭
java·jvm·c++