蓝桥杯(路径 动态规划 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;
}
相关推荐
张健11564096489 小时前
使用信号量限制并发数量
开发语言·c++
jc06209 小时前
6.1云原生之Docker
c++·docker·云原生
叶子野格11 小时前
《C语言学习:指针》12
c语言·开发语言·c++·学习·visual studio
Fuyo_111912 小时前
C++ 内存管理
c++·笔记
澈20713 小时前
C++面向对象:类与对象核心解析
c++·算法
6Hzlia13 小时前
【Hot 100 刷题计划】 LeetCode 141. 环形链表 | C++ 哈希表直觉解法
c++·leetcode·链表
handler0114 小时前
Linux 进程探索:从 PCB 管理到 fork() 的写时拷贝
linux·c语言·c++·笔记·学习
众少成多积小致巨14 小时前
GNU Make 核心指南
android·c++
谭欣辰15 小时前
详细讲解 C++ 状压 DP
开发语言·c++·动态规划
William_wL_15 小时前
【C++】stack和queue的使用和实现(附加deque的简单介绍)
开发语言·c++