添在前面的一句话:初学DP,若有错误,请指出,不能误人子弟,欢迎大家提出意见.水平不高,博客写的比较粗糙,代码也挺丑,请见谅.

最原始的数字三角形:

1220 数字三角形

 时间限制: 1 s
 空间限制: 128000 KB
 题目等级 : 黄金 Gold
 
 
 
题目描述 Description

如图所示的数字三角形,从顶部出发,在每一结点可以选择向左走或得向右走,一直走到底层,要求找出一条路径,使路径上的值最大。

输入描述 Input Description

第一行是数塔层数N(1<=N<=100)。

第二行起,按数塔图形,有一个或多个的整数,表示该层节点的值,共有N行。

输出描述 Output Description

输出最大值。

样例输入 Sample Input

5

13

11 8

12 7 26

6 14 15 8

12 7 13 24 11

样例输出 Sample Output

86

数据范围及提示 Data Size & Hint
 

思路:因为f[i][j] 从 f[i + 1][j] 或者 f[i + 1][j + 1] 转移过来,但是我们要的是最大路径长度,所以从max(f[i +1][j],f[i + 1][j + 1])是最优解,所以DP转移方程为f[i][j]  += max(f[i + 1][j],f[i + 1][j + 1]);

代码:

 #include <iostream>
#include <cstdio>
#define X 1007 int f[X][X]; int max(int x,int y){
return x > y ? x : y;
} inline int read(){
int x = ,f = ;char c = getchar();
while(c < '' || c > ''){if(c == '-')f = -;c = getchar();}
while(c >= '' && c <= ''){x = x * + c - '';c = getchar();}
return x * f;
} int main(){
int n;
n = read();
for(int i = ;i <= n;++ i)
for(int j = ;j <= i;++ j)
f[i][j] = read();
for(int i = n - ;i >= ;-- i)
for(int j = ;j <= i;++ j)
f[i][j] += max(f[i + ][j],f[i + ][j + ]);
printf("%d",f[][]);
}

数字三角形w

2189 数字三角形W

 时间限制: 1 s
 空间限制: 32000 KB
 题目等级 : 黄金 Gold
 查看运行结果
 
 
题目描述 Description

数字三角形
要求走到最后mod 100最大

输入描述 Input Description

第1行n,表示n行
第2到n+1行为每个的权值

输出描述 Output Description

mod 100最大值

样例输入 Sample Input

2
1
99 98

样例输出 Sample Output

99

数据范围及提示 Data Size & Hint

n<=25

思路:根据mod 100这个条件,按照上一个题,已经不满足与最优子结构,所以我们要加一维。

可达性DP,我们开一个bool数组 f[i][j][k],f[i][j][k]表示i行,j列,从下面到k值能不能走通,所以我们就想出DP转移方程了,f[i][j][k] = f[i + 1][j][v] | f[i + 1][j + 1][v];(v = (k + 100 - a[i][j] %100) % 100)(ps:这个地方挺重要的,如果k数值 < a[i][j]的话,就会成为负数,然而他是比a[i][j]要大的,所以我们加上一个100也没有关系,建议这个地方好好领悟.先让a[i][j] % 100可以有效的防a[i][j] > k + 100

代码:

 #include <iostream>
#include <cstdio>
#define X 30 int a[X][X];
bool f[X][X][];//f[i][j][k] i 表示 第i行 j表示第j列 k表示上面的路径%100到k这个值 bool型数组,能到k值为1,到不了为0 int max(int x,int y){
return x > y ? x : y;
}//max函数,我没用using namespace std inline int read(){
int x = ,f = ;char c = getchar();
while(c < '' || c > ''){if(c == '-')f = -;c = getchar();}
while(c >= '' && c <= ''){x = x * + c - '';c = getchar();}
return x * f;
}//快读 不解释 int main(){
int n,ans = ;//n 如题 有n层的数字三角形
n = read();
for(int i = ;i <= n;++ i)
for(int j = ;j <= i;++ j)
a[i][j] = read();//读入三角形
for(int i = ;i <= n;++ i)f[n][i][((a[n][i] % ) + ) % ] = true;//在最下面一层,不会有人转移到他
//所以这是初始条件,a[n][i] % 100 这个值会到达,所以标记为true
for(int i = n - ;i >= ;-- i){
for(int j = ;j <= i;++ j){
for(int k = ;k <= ;++ k){
int v = (k - (a[i][j] %) + ) % ;
f[i][j][k] = f[i + ][j][v] | f[i + ][j + ][v];
}
}
}//核心代码,根据条件很容易得到DP转移方程 f[i][j][k] = f[i + 1][j] [(k - a[i][j]) % 100] | f[i + 1][j + 1][(k - a[i][j]) % 100];
for(int i = ;i >= ;-- i)
if(f[][][i]){ans = i;break;}//从后往前推,如果这个到达了这个i值,直接break就好.
printf("%d",ans);
}

数字三角形ww

2193 数字三角形WW

 时间限制: 1 s
 空间限制: 32000 KB
 题目等级 : 钻石 Diamond
 
 
 
题目描述 Description

数字三角形必须经过某一个点,使之走的路程和最大

输入描述 Input Description

第1行n,表示n行
第2到n+1行为每个的权值
程序必须经过n div 2,n div 2这个点

输出描述 Output Description

最大值

样例输入 Sample Input

#include <iostream>
#include <cstdio>
#define X 30 int f[X][X]; inline int read(){
int x = ,f = ;char c = getchar();
while(c < '' || c > ''){if(c == '-')f = -;c = getchar();}
while(c >= '' && c <= ''){x = x * + c - '';c = getchar();}
return x * f;
} int max(int x,int y){
return x > y ? x : y;
} int main(){
int n = read(),x;
for(int i = ;i <= n;++ i)
for(int j = ;j <= i;++ j)
f[i][j] = read();
for(int i = ;i < n / ;++ i)f[n/][i] = -0x3f3f3f3f;
for(int i = n - ;i >= ;-- i){
for(int j = ;j <= i;++ j){
f[i][j] += max(f[i + ][j],f[i + ][j + ]);
}
}
printf("%d",f[][]);
}

2
1
1 1

样例输出 Sample Output

2

数据范围及提示 Data Size & Hint

n <=25

思路:只能走f[n / 2][n / 2]这条路,我们就好在n / 2这一行的除了f[n / 2][n / 2]全部设成最小值就可以了.

代码:

 #include <iostream>
#include <cstdio>
#define X 30 int f[X][X]; inline int read(){
int x = ,f = ;char c = getchar();
while(c < '' || c > ''){if(c == '-')f = -;c = getchar();}
while(c >= '' && c <= ''){x = x * + c - '';c = getchar();}
return x * f;
} int max(int x,int y){
return x > y ? x : y;
} int main(){
int n = read(),x;
for(int i = ;i <= n;++ i)
for(int j = ;j <= i;++ j)
f[i][j] = read();
for(int i = ;i < n / ;++ i)f[n/][i] = -0x3f3f3f3f;
for(int i = n - ;i >= ;-- i){
for(int j = ;j <= i;++ j){
f[i][j] += max(f[i + ][j],f[i + ][j + ]);
}
}
printf("%d",f[][]);
}

数字三角形WWW:

2198 数字三角形WWW

 时间限制: 1 s
 空间限制: 32000 KB
 题目等级 : 钻石 Diamond
 
 
 
题目描述 Description

数字三角形必须经过某一个点,使之走的路程和最大

输入描述 Input Description

第1行n,表示n行 
第2到n+1行为每个的权值
第n+2行为两个数x,y表示必须经过的点

输出描述 Output Description

最大值

样例输入 Sample Input

2
1
1 1
1 1

样例输出 Sample Output

2

数据范围及提示 Data Size & Hint

n<=25

思路:同上一题差不多,就是将n / 2那一行改成x,然后特判一下y位置就好了,不多说,上代码.

代码:

 #include <iostream>
#include <cstdio>
#define X 30 int f[X][X]; inline int read(){
int x = ,f = ;char c = getchar();
while(c < '' || c > ''){if(c == '-')f = -;c = getchar();}
while(c >= '' && c <= ''){x = x * + c - '';c = getchar();}
return x * f;
} int max(int x,int y){
return x > y ? x : y;
} int main(){
int n = read(),x,y,tmp;
for(int i = ;i <= n;++ i)
for(int j = ;j <= i;++ j)
f[i][j] = read();
x = read(),y = read();
tmp = f[x][y];
for(int i = ;i <= x;++ i)f[x][i] = -0x3f3f3f3f;
f[x][y] = tmp;
for(int i = n - ;i >= ;-- i){
for(int j = ;j <= i;++ j){
f[i][j] += max(f[i + ][j],f[i + ][j + ]);
}
}
printf("%d",f[][]);
}

codevs 数字三角形集结的更多相关文章

  1. Codevs 数字三角形 问题合集

    1220 数字三角形 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 如图所示的数字三角形,从顶部出发,在每一结点可以选择向左走或得 ...

  2. codevs——T1220 数字三角形

    http://codevs.cn/problem/1043/  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Descr ...

  3. codevs 1220 数字三角形

    1220 数字三角形  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解       题目描述 Description 如图所示的数字三角形,从顶部出发,在每 ...

  4. codevs——1220 数字三角形(棋盘DP)

     时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解       题目描述 Description 如图所示的数字三角形,从顶部出发,在每一结点可以选择向左走或 ...

  5. [CODEVS] 2193 数字三角形WW

    数字三角形必须经过某一个点,使之走的路程和最大 从必须经过的点,向上向下分别DP两次的和即为答案. 还有一种思路是把和必须经过点同一行的设为-INF,这样就一定(大概)不会选择它们了. //Write ...

  6. [CODEVS] 2189 数字三角形W

    数字三角形 要求走到最后mod 100最大 可达性DP(好像是这样叫) 用bool数组f[i][j][k]表示 位置(i,j)能否得到k(mod 100意义下) 转移条件 f[i][j][k]=f[i ...

  7. Codevs 4829 [DP]数字三角形升级版

    4829 [DP]数字三角形升级版 时间限制: 1 s 空间限制: 16000 KB 题目等级 : 黄金 Gold 题目描述 Description 从数字三角形的顶部(如图,第一行的5表示行数)到底 ...

  8. 数字三角形W(加强版) codevs 2189

    2189 数字三角形W 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold 题目描述 Description 数字三角形 要求走到最后mod 100最大 输入描述 Inpu ...

  9. G:数字三角形

    总时间限制: 1000ms 内存限制: 65536kB描述73   88   1   02   7   4   44   5   2   6   5 (图1) 图1给出了一个数字三角形.从三角形的顶部 ...

随机推荐

  1. Some JPR highlights (JPR 2019 March)

    Journal Name:Journal of Proteome Research Issue:2019 March Shared by: Weining Zhao 1.     Acetylome: ...

  2. 图片美化增强AI接口调用手册

    在调合合AI平台提供的图片美化增强API接口,API平台链接:https://ai.ccint.com/doc/api/crop_enhance_image, 因为有遇到一些问题,写篇博客记录一下 A ...

  3. vi/vim打开文件提示Found a swap file by the name

    问题分析 有一次在远程连接主机时,用vi打开文件my.ini却提示:Found a swap file by the name ".my.ini.swp".百度了下才知道,原来在使 ...

  4. Hive_Hive的数据类型

    Hive Basic Data Type: Basic Types: tinyint/samllint/int/bigint float/double boolean string Complex T ...

  5. springMVC-上传图片

    SpringMVC文件上传与下载 上传图片 配置多媒体文件解析器 配置虚拟目录 在tomcat上配置图片虚拟目录,在tomcat下conf/server.xml中添加: <Context doc ...

  6. 如何实现序列化为json

    因为需要观察对象的数据,所以寻找能自动描述对象中字段名和其值的描述类,咨询了不少人,都推荐使用json,但是json使用起来有一点额外的操作. 需要在文件中引用 using System.Web.Sc ...

  7. HTML文档设置标记

    格式标记 1.<br> 强制换行标记,让后面的文字.图片.表格等,显示在下一行.单标记 2.<p> 换段落标记,换段落是由于多个空格和回车在HTML中会被等效为一个空格,所以H ...

  8. 详解JS作用域(一)

    一.什么是作用域 存储和访问变量,是任何一种编程语言最基本的功能之一,变量存在哪里?程序需要时如何找到它?这些问题需要一套良好的规则来规范,这套规则,就成为作用域. 二.编译原理 js通常归类为解释语 ...

  9. Github开源项目单

    以下涉及到的数据统计与 2019 年 5 月 1 日 12 点,数据来源:https://github.com/trending/java?since=monthly . 下面的内容从 Java 学习 ...

  10. Linux--NiaoGe-Service-04

    操作系统版本:CentOS 6.10 x86_64 查看内核所获取到的网卡信息 [root@xueji ~]# dmesg | grep -in eth :e1000 ::-bit) :0c::6b: ...