当前位置:   article > 正文

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

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

附代码

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int get_length(int a, int b) {
  4. for (int i = max(a, b); i <= a * b; i++) {
  5. if (i % a == 0 && i % b == 0)
  6. return i;
  7. }
  8. return 0;
  9. }
  10. int main() {
  11. int dp[2022];
  12. for (int i = 0; i < 2022; i++) {
  13. dp[i] = INT_MAX;
  14. }
  15. dp[1] = 0;
  16. for (int i = 1; i < 2022; i++) {
  17. for (int j = i + 1; j <= i + 21&&j<2022; j++) {
  18. dp[j] = min(dp[i] + get_length(i, j), dp[j]);
  19. }
  20. }
  21. cout << dp[2021];
  22. return 0;
  23. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/697837
推荐阅读
相关标签
  

闽ICP备14008679号