2021第十二届蓝桥杯省赛C++A组:路径(动态规划)

题目描述

 解题思路

对于该题,两节点之差绝对值大于21则不连通,故转移时只需考虑与该节点之差绝对值小于21的节点。

考虑动态规划解法,dp[i]表示为节点1到节点i的最短距离,初始状态dp[1]=0,动态转移方程为dp[j] = min(dp[i] + get_length(i, j), dp[j]),即结点j是否被选入路径中由dp[i]+结点i和j之间的距离决定,最终输出dp[2021]即为正确结果

答案:10266837

附代码

#include<bits/stdc++.h>
using namespace std;
int get_length(int a, int b) {
	for (int i = max(a, b); i <= a * b; i++) {
		if (i % a == 0 && i % b == 0)
			return i;
	}
	return 0;
}
int main() {
	int dp[2022];
	for (int i = 0; i < 2022; i++) {
		dp[i] = INT_MAX;
	}
	dp[1] = 0;
	for (int i = 1; i < 2022; i++) {
		for (int j = i + 1; j <= i + 21&&j<2022; j++) {
			dp[j] = min(dp[i] + get_length(i, j), dp[j]);
		}
	}
	cout << dp[2021];
	return 0;
}

相关推荐

  1. 2021 C&C++ 研究生2.0

    2024-04-21 14:56:01       37 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-21 14:56:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-21 14:56:01       101 阅读
  3. 在Django里面运行非项目文件

    2024-04-21 14:56:01       82 阅读
  4. Python语言-面向对象

    2024-04-21 14:56:01       91 阅读

热门阅读

  1. 两个表归并为有序表

    2024-04-21 14:56:01       28 阅读
  2. vscode远程ubuntu16安装失败

    2024-04-21 14:56:01       31 阅读
  3. K8S之Resource Quotas

    2024-04-21 14:56:01       134 阅读
  4. 李沐47_转置卷积

    2024-04-21 14:56:01       194 阅读
  5. Redis中的Lua脚本(一)

    2024-04-21 14:56:01       37 阅读
  6. IO系列-2 Protobuf使用说明

    2024-04-21 14:56:01       37 阅读
  7. 什么是 jdbc,及其的作用

    2024-04-21 14:56:01       38 阅读