/*
* File name : digital_tower.cpp
* Function : 动态规划 数塔问题求解 C++实现
* Created on : 2016年6月17日
* Author : beijiwei@qq.com
* Copyright : 欢迎大家和我一起交流学习,转载请保持源文件的完整性。
任何单位和个人不经本人允许不得用于商业用途
9
12 15
10 6 8
2 18 9 5
19 7 10 4 16
从顶层或底层 走,在每一节点可选择左走或者右走.
求一条路径,使得到的数值和最大.
input:
9
12 15
10 6 8
2 18 9 5
19 7 10 4 16
*/
#include
#include
#pragma warning(disable:4996)
using namespace std;
#define M 5
int get_max(int x, int y);
int main(int argc, char** argv)
{
int i = 0, j = 0, k = 0;
int map[M][M];
int result[M][M];
freopen("input.txt", "r", stdin);
memset(result, 0, sizeof(int)*M*M);
memset(map, 0, sizeof(int)*M*M);
for (i = 0; i {
for (j = 0; j
{
cin >> map[i][j];
if (i == M - 1)
{
result[i][j] = map[i][j];
}
}
}
for (k = M - 2; k >= 0; k--)//上塔 第k层,
{
for (i = 0; i {
result[k][i] = get_max(map[k][i] + result[k + 1][i], map[k][i] + result[k + 1][i+1]);
}
}
cout <int target &#61; result[0][0] - map[0][0];
cout <