hdu2084 与 hdu 1176 的不同与思考
来源:互联网 发布:免费数据管理软件 编辑:程序博客网 时间:2024/06/06 03:53
hdu1761其实本质上来说也是数塔问题,就把这两道题拿到一起说了
对于hdu2084,网上很多代码用二维的dp数组,其实一维的就可以,重复利用更节约空间,可以参考背包问题时对于二维dp数组的优化,这题只向下找2个元素,新结果覆盖了被淘汰的元素可以优化成一维数组;
而hdu1761这题是取三个元素所以不管是正序还是逆序都会把下次需要取用的元素覆盖掉,所以不能优化成一维数组;
本质上来讲数塔问题需要从下到上来求解,才更方便一些;
两道题的详情看注释;
AC代码:
//hdu 2084#include <stdio.h>#include <string.h>#include <algorithm>using namespace std;int main(){ int i,j,n,Case; int num[109][109],dp[109]; scanf("%d",&Case); while(Case--) { scanf("%d",&n); memset(dp,0,sizeof(dp)); for(i = 1 ; i <= n ; i++) for(j = 1 ; j <= i ;j++) scanf("%d",&num[i][j]); for(i = n ; i >= 1 ;i--) for(j = 1 ; j <= i ; j++) dp[j] = max(dp[j],dp[j+1]) + num[i][j]; //从下向上找就方便很多了 printf("%d\n",dp[1]); } return 0;}
//hdu 1176#include <stdio.h>#include <string.h>#include <algorithm>using namespace std;int num[100020][20],dp[100020][20];//数组要开的大一些int main(){ int i,j,n,pos,time,maxtime; while(~scanf("%d",&n) && n)//n为0时跳出 { maxtime = 0; memset(dp,0,sizeof(dp)); memset(num,0,sizeof(num)); for(i = 0 ; i < n ; i++) { scanf("%d%d",&pos,&time) ; num[time][pos]++; maxtime = max(maxtime,time);//找出边界的最大时间 } for(i = maxtime ; i >= 0 ;i--) { dp[i][0] = max(dp[i+1][1],dp[i+1][0]) + num[i][0]; dp[i][10] = max(dp[i+1][10],dp[i+1][9]) + num[i][10];//在边上的两个元素单独去求 for(j = 1 ; j <= 9 ; j++) dp[i][j] = max(max(dp[i+1][j-1],dp[i+1][j]),dp[i+1][j+1]) + num[i][j]; } printf("%d\n",dp[0][5]);//起始地点是5,得出结果 } return 0;}
0 0
- hdu2084 与 hdu 1176 的不同与思考
- 来自不同领域的问题与思考
- 人与人的差别仅在于思考问题的方式不同
- 【思考】毕业季的纠结与思考
- &与在&&的不同
- LINUX与WINDWOS的思考
- 人 与电脑的思考
- 前进与问题的思考
- CSLA与分层的思考
- DataTable与对象的思考
- 我的思考与成长
- LinkedList 与 ArrayList的思考
- 产品与人性的思考
- 产品与人性的思考
- typedef与define的思考 .
- 软件与硬件的思考
- 软件设计的思考与关注点
- paas与iaas的思考
- Hibernate与MyBatis的对比总结
- Rust语法之注释
- 例题11-2 苗条的生成树 UVa1395 Kruskal算法样例(基于并查集,which is almost like set)
- vi 命令实现特需需求
- ORA-00205: ?????????????????????解决方案
- hdu2084 与 hdu 1176 的不同与思考
- 提高xcode编译运行速度
- tomcat utf-8字符集中文变问号问题
- 利用DrawDragRect画出类似截图的功能
- objective-c基础教程(笔记)
- Android Volley完全解析(二),使用Volley加载网络图片
- 栈的基本操作
- hdu 2002计算球体积(java)
- HDU1203 DP-01背包