蓝桥杯(路径 动态规划 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;
}
相关推荐
思麟呀26 分钟前
C++14概述与三大核心语法改进
开发语言·c++
Lhan.zzZ37 分钟前
Qt Quick 嵌套 Dialog 与 ComboBox 层级混乱问题解决
c++·qt
Irissgwe44 分钟前
AVL树详解
数据结构·c++·算法·二叉树·c·二叉搜索树·avl
剑锋所指,所向披靡!1 小时前
进程间通信IPC
c++
凌波粒1 小时前
LeetCode--131.分割回文串(回溯算法)
算法·leetcode·职场和发展
小小晓.1 小时前
零基础C++小白突破
开发语言·c++
阿i索1 小时前
【C++学习笔记】【基础】4.string类(2)——模拟实现
c++·笔记·学习
我不是懒洋洋1 小时前
从零实现一个消息队列:生产消费与持久化
c++
玖玥拾1 小时前
C/C++ 数据结构(五)链表的应用、对象池
c语言·数据结构·c++·链表·对象池·双向链表
John_ToDebug2 小时前
Windows客户端热修复技术:从原理到工程实践
c++·经验分享·hook