HDU 1087 Super Jumping! Jumping! Jumping
2016-03-07 00:12
302 查看
HDU 1087
题目大意:给定一个序列,只能走比当前位置大的位置,不可回头,求能得到的和的最大值。(其实就是求最大上升(可不连续)子序列和)
解题思路:可以定义状态dp[i]表示以a[i]为结尾的上升子序列的和的最大值,那么便可以得到状态转移方程
dp[i] = max(dp[i], dp[j]+a[i]), 其中a[j]<a[i]且j<i; 另外每个dp[i]可以先初始化为a[i]
理解:以a[i]为结尾的上升子序列可以由前面比a[i]小的某个序列加上a[i]来取得,故此有dp[j]+a[i], j < i, a[j] < a[i]三个条件
若是前面没有比a[i]小的序列,那么dp[i]为a[i]本身,故此有dp[i]全初始化为a[i]。
最后获取dp[i]数组中的最大值就是最终结果了。
/* HDU 1087 Super Jumping! Jumping! Jumping! --- dp */ #include <cstdio> #include <cstring> int a[1005]; int dp[1005]; inline int MAX(int a, int b){ return a > b ? a : b; } int main() { #ifdef _LOCAL freopen("D:input.txt", "r", stdin); #endif int n; while (scanf("%d", &n) == 1 && n){ for (int i = 1; i <= n; ++i){ scanf("%d", a + i); //获取n个数 dp[i] = a[i]; //dp[i]的初始化 }//for(i) //dp[i] = max(dp[i], dp[j]+a[i]), 其中a[j] < a[i] int maxnum = dp[1]; //max保存最终结果 for (int i = 1; i <= n; ++i){ for (int j = 1; j <= i; ++j){ if (a[j] < a[i]){ dp[i] = MAX(dp[i], dp[j] + a[i]); if (dp[i] > maxnum){ maxnum = dp[i]; } } }//for(j) }//for(i) printf("%d\n", maxnum); } return 0; }
View Code
相关文章推荐
- 代码思路跟我的不一样,感觉很好
- 7-2-图的邻接表存储-图-第7章-《数据结构》课本源码-严蔚敏吴伟民版
- android--存储
- python数据类型之字符串
- JS冒泡与阻止
- installation failed since the device possibly has stale dexed jars that don't match the current vers
- Python List 删除元素
- 安卓第七天笔记--网络编程一
- UIDatePicker
- The Engine Document of JustWeEngine
- thinking for android's animation
- ImageView 的使用
- 生成模型与判别模型
- MySQL基础语法(一)
- 语言基础:C#运算符
- ZOJ 1709 Oil Deposits(DFS)
- iOS实现书架布局样式【一些电子书的首页】
- tomcat错误之:Exception loading sessions from persistent storage java.io.EOFException
- Java微信公众平台开发(2) 微信服务器post消息体的接收
- Zend Framework教程之前端控制器Zend_Controller_Front用法详解