(数字三角形)POJ1163 The Triangle
| Time Limit: 1000MS | Memory Limit: 10000K | |
| Total Submissions: 59698 | Accepted: 35792 | 
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
Output
Sample Input
5
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5
Sample Output
30
DP水题,记忆化递归和递推都行,其状态转换式为 dp[i][j] = a[i][j] + max{d[i+1][j],d[i+1][j+1]};
C++代码:
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
using namespace std;
const int maxn = ;
int a[maxn][maxn];
int dp[maxn][maxn];
int main(){
int N;
scanf("%d",&N);
memset(a,,sizeof(a));
for(int i = ; i <= N; i++){
for(int j = ; j <= i; j++)
cin>>a[i][j];
}
memset(dp,-,sizeof(dp));
for(int i = ; i <= N; i++)
dp[N][i] = a[N][i];
for(int i = N-; i >= ;i--){
for(int j = ; j <= i; j++)
dp[i][j] = max(dp[i+][j],dp[i+][j+]) + a[i][j];
}
printf("%d\n",dp[][]);
return ;
}
(数字三角形)POJ1163 The Triangle的更多相关文章
- 动态规划略有所得 数字三角形(POJ1163)
		在上面的数字三角形中寻找一条从顶部到底边的路径,使得路径上所经过的数字之和最大.路径上的每一步都只能往左下或 右下走.只需要求出这个最大和即可,不必给出具体路径. 三角形的行数大于1小于等于100,数 ... 
- 动态规划之数字三角形(POJ1163)
		在下面的数字三角形中寻找一条从顶部到底边的路径,使得路径上所经过的数字之和最大.路径上的每一步都只能往左下或 右下走.只需要求出这个最大和即可,不必给出具体路径. 既然求目标问题是根据查表得来的,自然 ... 
- 动态规划入门——数字三角形(Java)
		动态规划的概念对于新手来说枯燥难懂,就算看懂了,做题的时候依旧抓耳挠腮的毫无头绪,这些比较难理解的算法,还是需要根据例子来一步步学习和理解,从而熟练掌握,下面,咱们就通过一个简单的小例子来学习动态规划 ... 
- dp递推 数字三角形,dp初学者概念总结
		数字三角形(POJ1163) 在上面的数字三角形中寻找一条从顶部到底边的路径,使得路径上所经过的数字之和最大.路径上的每一步都只能往左下或 右下走.只需要求出这个最大和即可,不必给出 ... 
- 数字三角形 · Triangle
		从上到下用DP. [抄题]: 给定一个数字三角形,找到从顶部到底部的最小路径和.每一步可以移动到下面一行的相邻数字上. 比如,给出下列数字三角形: [ [2], [3,4], [6,5,7], [4, ... 
- lintcode:数字三角形
		题目: 数字三角形 给定一个数字三角形,找到从顶部到底部的最小路径和.每一步可以移动到下面一行的相邻数字上. 样例 比如,给出下列数字三角形: [ [2], [3,4], [6 ... 
- DP入门(1)——数字三角形问题
		一.问题描述 如上图所示,有一个由非负整数组成的三角形,第一行只有一个数,除了最下行之外每个数的左下方和右下方各有一个数.现请你在此数字三角形中寻找一条从首行到最下行的路径,使得路径上所经过的数字之和 ... 
- Problem C: 动态规划基础题目之数字三角形
		Problem C: 动态规划基础题目之数字三角形 Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 208 Solved: 139[Submit][Sta ... 
- G:数字三角形
		总时间限制: 1000ms 内存限制: 65536kB描述73 88 1 02 7 4 44 5 2 6 5 (图1) 图1给出了一个数字三角形.从三角形的顶部 ... 
- 4829 [DP]数字三角形升级版
		4829 [DP]数字三角形升级版 时间限制: 1 s 空间限制: 16000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description 从数字三角形的顶部(如图, ... 
随机推荐
- 文件操作 chardet使用
			#_*_coding:utf-8_*_ import chardet #f = open(file="兼职白领学生空姐模特护士联系方式.txt", mode="rb&qu ... 
- 动态sql and在前 逗号在后
- MySQL数据库安装配置
			1,下载MySQL 打开MySQL的官网www.mysql.com,发现有一个DOWNLOADS 点击它,进入到MySQL的下载页面,在页面的底部有一个MySQL Community Edition, ... 
- linq之左连接 + group by
			var list = from item in (from s in _sysBll.GetList(s => s.ParamID == "TraSchType" & ... 
- Maven添加Web.xml的方法
			当创建maven工厂时没有web.xml文件1.点击你的项目名称,进入到Myeclipse的-- Project Facets上,2.点击Dynamic Web Module 和下面的Java,将两个 ... 
- [IOI2018]组合动作——构造
			题目连接: [IOI2018]combo 题目大意:有一个未知的长度为n的字符串$T$,只包含$A,B,X,Y$四个字符且首字母只出现一次,每一次你可以询问一个长度不超过$4n$的字符串$S$,交互库 ... 
- BZOJ3230 相似子串 【后缀数组】
			题目分析: 容易想到sa排好序之后,子串排名就是前面的子串减去height数组.所以正着做一遍,倒着做一遍就行了. 代码: #include<bits/stdc++.h> using na ... 
- hashlib 模块用来进行hash
			hashlib的基本概述: python中的 hashlib 模块用来进行hash 或者md5加密,而且这种加密是不可逆的,所以这种算法又被称为摘要算法, 其支持Opennssl库提供的所有算法,包括 ... 
- Modelsimse10.4如何编译altera库文件以支持IP仿真
			前言 se版本默认没有ip之类的库支持,如果你用到了pll之类的ip,仿真前就得把库编译好. 版本:Modelsim10.4se 流程 readme:实现有版本两个,任选.理论都是一样的,把v文件编译 ... 
- GitHub Desktop 出现“please upgrade your plan to create a new private repository”的解决办法
			转:https://blog.csdn.net/qq_38584262/article/details/82386805 解决办法:去掉最下面的勾 
