蓝桥杯(路径 动态规划 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;
}
相关推荐
alwaysrun8 分钟前
C++之常量体系const
c++·后端·程序员
郝学胜_神的一滴9 分钟前
CMake 016:深入浅出变量核心用法
c++·cmake
学逆向的15 分钟前
C++模板
开发语言·c++·网络安全
凡人叶枫30 分钟前
Effective C++ 条款24:若所有参数皆须要类型转换,请为此采用 non-member 函数
linux·前端·c++·算法·嵌入式开发
j7~35 分钟前
【C++】STL--string类--拆析解剖string类的实现以及string类的底层详解(2)
开发语言·c++·浅拷贝·深拷贝·string类的实现·string拷贝构造·string赋值重载
DogDaoDao1 小时前
C++核心技术深度剖析:从底层原理到工程实践
开发语言·c++·面试·程序员·指针·虚函数
磊 子1 小时前
C++移动语义和智能指针
java·开发语言·c++
枫子有风1 小时前
LLM-RAG(大厂面试常问问题)
面试·职场和发展·llm·rag
不负岁月无痕1 小时前
C++继承与多态知识点及其高频面试问题
开发语言·c++·面试
Tairitsu_H1 小时前
[LC优选算法#4] 滑动窗口 | 串联所有单词的⼦串 | 最⼩覆盖⼦串
c++·算法·滑动窗口