蓝桥杯(路径 动态规划 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;
}
相关推荐
凯瑟琳.奥古斯特2 分钟前
IP组播跨子网传输核心技术解析
java·开发语言·网络·网络协议·职场和发展
蜡笔小马3 分钟前
09.C++设计模式-外观模式
c++·设计模式·外观模式
2301_800895104 分钟前
蓝桥杯第十二届b组国赛真题--备战国赛版h
算法·蓝桥杯
晚会者荣7 分钟前
C++11_3:包装器,智能指针
c++
handler0111 分钟前
TCP(传输控制协议)核心机制与底层原理
linux·网络·c++·笔记·网络协议·tcp/ip·操作系统
王老师青少年编程11 分钟前
csp信奥赛C++高频考点专项训练之字符串 --【字符串综合】:遍历问题
c++·字符串·csp·高频考点·信奥赛
代码柏拉图11 分钟前
AI时代如何提问面试者
人工智能·面试·职场和发展
yoyo_zzm14 分钟前
五大编程语言对比:PHP、C、C++、C#、易语言
c语言·c++·php
杰之行18 分钟前
Fast-DDS Transport 层架构详解
c++·人工智能
_深海凉_19 分钟前
LeetCode热题100-对称二叉树
算法·leetcode·职场和发展