poj-1163-The Triangle

简介: Description 73 88 1 02 7 4 44 5 2 6 5(Figure 1) Figure 1 shows a number triangle.

Description

7
3 8
8 1 0
2 7 4 4
4 5 2 6 5

(Figure 1)
Figure 1 shows a number triangle. Write a program that calculates the highest sum of numbers passed on a route that starts at the top and ends somewhere on the base. Each step can go either diagonally down to the left or diagonally down to the right.

Input

Your program is to read from standard input. The first line contains one integer N: the number of rows in the triangle. The following N lines describe the data of the triangle. The number of rows in the triangle is > 1 but <= 100. The numbers in the triangle, all integers, are between 0 and 99.

Output

Your program is to write to standard output. The highest sum is written as an integer.

Sample Input

5
7
3 8
8 1 0 
2 7 4 4
4 5 2 6 5

Sample Output

30
题目大意:
求从最上面到最下面的最大和;参照Figure 1图
#include<iostream>
using namespace std;
int main()
{

   int n,aa[100][100];
   cin>>n;
   for(int i=0;i<n;i++)
    for(int j=0;j<=i;j++)
    cin>>aa[i][j];

    for(int i=n-2;i>=0;i--)//为什么要n-2呢??
                //思路是从倒数第一行开始把值加到上面一行,这样得到的aa[0][0]一定是最大值 { for(int j=0;j<=i;j++) { aa[i][j]+=max(aa[i+1][j],aa[i+1][j+1]); } } cout<<aa[0][0]<<endl; return 0; }
例如:
5
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5
执行之后结果:
30
23 8
20 1 0
7 12 4 4
4 5 2 6 5

  



相关文章
|
6月前
|
机器学习/深度学习
poj 2155 Matrix (二维树状数组)
这是楼教主出的二维线段树或者是二维树状数组的题,题意很简单,就是有个n*n的矩阵,初始值都是0,然后给你两个操作,一个是给你左上角和右下角的坐标,把这个长方形的区间所有元素反取反(0变1 1变0),另一个是求某个具体坐标的值。 这里我用了二维的线树状数组,一维树状数组可以解决区间更新和点查询的问题,这里只需要加一维就可以了,代码比较好写,不过开始犯了很多低级的错误。
18 0
HDU-1071,The area(求面积水题)
HDU-1071,The area(求面积水题)
|
Java Go
POJ 1163 The Triangle
POJ 1163 The Triangle
84 0
Triangle Leetcode
Created by Wang, Jerry, last modified on Dec 20, 2015
92 0
Triangle Leetcode
LeetCode 118:杨辉三角 II Pascal's Triangle II
公众号:爱写bug(ID:icodebugs)作者:爱写bug 给定一个非负索引 k,其中 k ≤ 33,返回杨辉三角的第 k 行。 Given a non-negative index k where k ≤ 33, return the kth index row of the Pascal's triangle. Note that the row index starts from 0. 在杨辉三角中,每个数是它左上方和右上方的数的和。
886 0
Leetcode 118:Pascal's Triangle 杨辉三角
118:Pascal's Triangle 杨辉三角 Given a non-negative integer numRows, generate the first numRows of Pascal's triangle. 给定一个非负整数 numRows,生成杨辉三角的前 numRows 行。
955 0