蓝桥杯C/C++程序设计 往届真题汇总(进阶篇)

2024-02-26 1210阅读

温馨提示:这篇文章已超过415天没有更新,请注意相关的内容是否还可用!

文章目录

    • 1. 最短路
    • 2. 数字三角形
    • 3. 递增序列
    • 4. 杨辉三角形
    • 5. 跳跃
    • 6. 路径
    • 7. 迷宫
    • 8. 装饰珠
    • 9. 明码
    • 10. 字串分值
    • 11. 作物杂交
    • 12. 承压计算
    • 13. 全球变暖
    • 14. 直线
    • 15. 平面切分

      1. 最短路

      题目描述:

      如下图所示,G是一个无向图,其中蓝色边的长度是1、橘色边的长度是2、绿色边的长度是3。

      蓝桥杯C/C++程序设计 往届真题汇总(进阶篇)

      则从 A 到 S 的最短距离是多少?

      #include 
      #include 
      using namespace std;
      const int N=200,n=19;
      int dist[N];
      int g[N][N];
      void add(char x,char y,int c)
      {
        int a=x-'A'+1;
        int b=y-'A'+1;
        g[a][b]=g[b][a]=c;
      }
      bool vis[N];
      int dijkstra()
      {
        memset(dist,0x3f,sizeof dist);
        dist[1]=0;
        for(int i=0;i
          int t=-1;
          for(int j=1;j
            if(!vis[j]&&(t==-1||dist[j]
            dist[j]=min(dist[j],dist[t]+g[t][j]);
          }
        }
        return dist[n];
      }
      int main()
      {
          memset(g,0x3f,sizeof g);
          add('A','B',2);
          add('A','C',1);
          add('A','D',1);
          add('A','D',1);
          add('B','J',2);
          add('B','G',1);
          add('C','D',3);
          add('C','F',3);
          add('C','G',3);
          add('D','E',1);
          add('D','G',2);
          add('D','H',1);
          add('D','I',2);
          add('E','H',1);
          add('E','I',3);
          add('F','G',1);
          add('F','J',1);
          add('G','F',1);
          add('G','I',3);
          add('G','K',2);
          add('H','I',1);
          add('H','L',2);
          add('I','M',3);
          add('J','S',2);
          add('K','N',1);
          add('K','L',3);
          add('K','P',2);
          add('L','M',1);
          add('L','R',1);
          add('M','N',2);
          add('M','Q',1);
          add('M','S',1);
          add('N','P',1);
          add('O','P',1);
          add('O','Q',1);
          add('O','R',3);
          add('R','S',1);
          cout
          int n;
          cinn;
          for(int i=1;i
              for(int j=1;j
              for(int j=1;j
                  if(j==1)dp[i][j]=dp[i-1][j]+a[i][j];
                  else if(j==i)dp[i][j]=dp[i-1][j-1]+a[i][j];
                  else dp[i][j]=max(dp[i-1][j],dp[i-1][j-1])+a[i][j];
              }
          }
          if(n%2==0){
              cout
              cout
          char str[35][55];
          long int ans = 0;
          for(int i=0; i
                cin  str[i][j];
              }
          
          for(int i=0; i
                  int k;
                  for(k=1; k+j
                      if(str[i][j] 
VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]