蓝桥杯-数字三角形

cpp 复制代码
#include <iostream>
#include <bits/stdc++.h>
using namespace std;
const int N=110;
int n;
int a[N][N];
int f[N][N];
int main()
{
  scanf("%d",&n);
  //1.输入图形
  for(int i=1;i<=n;i++)
    for(int j=1;j<=i;j++)
     scanf("%d",&a[i][j]);
   
  //2.情形1
  f[1][1]=a[1][1];
  //3.开始遍历
  for(int i=2;i<=n;i++)
  {
    for(int j=1;j<=i;j++)
  {
  //4.情形2:左边球
     if(j==1)
     f[i][j]=f[i-1][j]+a[i][j];
     //5.情形3:右边球
     else if(i==j) f[i][j]=f[i-1][j-1]+a[i][j];//分成三种情况讨论
     //6.情形4:中间球
     else f[i][j]=max(f[i-1][j],f[i-1][j-1])+a[i][j];
  }
}
//5.对步数进行判断
 if(n%2==1) cout<<f[n][n/2+1];
  else cout<<max(f[n][n/2],f[n][n/2+1]);
  找规律发现如果n为奇数时,最后必然走到最后行最中间的数,如果为偶数,则取中间两个数的最大值,
  //因为向左下走的次数与向右下走的次数相差不能超过 1
   return 0;
}
相关推荐
csdn_aspnet5 小时前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
谙弆悕博士5 小时前
【附C源码】从零实现C语言堆数据结构:原理、实现与应用
c语言·数据结构·算法··数据结构与算法
gaosushexiangji9 小时前
DIC系统推荐:基于千眼狼三维数字图像相关的无人机旋翼疲劳试验全场应变与位移测量
人工智能·算法
小王C语言10 小时前
【线程概念与控制】:线程封装
jvm·c++·算法
kyle~10 小时前
工程数学---点云配准卡布施(Kabsch)算法(求解最优旋转矩阵)
线性代数·算法·矩阵
张二娃同学11 小时前
03_变量常量与输入输出_printf与scanf详解
算法
江南十四行11 小时前
并发编程(一)
java·jvm·算法
z2005093012 小时前
今日算法(依旧二叉树)
算法·leetcode·职场和发展
Zxc_12 小时前
《遗传算法:从自然选择到Rastrigin函数优化,手写一个完整的进化求解器》
算法
阿Y加油吧12 小时前
两道经典动态规划题:乘积最大子数组 & 分割等和子集 复盘笔记
笔记·算法·动态规划