LIS(即最长上升子序列)
来源:互联网 发布:相对湿度数据 编辑:程序博客网 时间:2024/06/10 11:06
这是一个经典的LIS(即最长上升子序列)问题,请设计一个尽量优的解法求出序列的最长上升子序列的长度。
给定一个序列A及它的长度n(长度小于等于500),请返回LIS的长度。
测试样例:
[1,4,2,5,3],5
返回:3
思路:用dp[i]数组来记录以i为结尾的子序列里面包含的最长上升子序列的数字个数。然后从下标为1开始求dp[i],并且记录找到的最大值,即可得到解。根据下面的DP方程就可以进行求解了:dp[i] = max{dp[j]+ 1,dp[i]}其中j < i && A[j] <A [i]
class LongestIncreasingSubsequence {public: int getLIS(vector<int> A, int n) { if(n <= 1) return n; vector<int> dp(n,1);//初始化数组为n个1 int max_length = 0;//最长上升子序列的个数 for (int i = 1; i < n; i++){ for (int j = 0; j < i; j++){ if(A[j] < A[i] && dp[i]<(dp[j]+1)) dp[i]=dp[j]+1;//i下标之前(包括i)的最长上升子序列的个数 } } for (int i = 0; i < n; i++) max_length = max(max_length, dp[i]); return max_length; }};
阅读全文
0 0
- LIS(即最长上升子序列)
- 最长上升子序列LIS
- 最长上升子序列LIS
- 最长上升子序列(LIS)
- 最长上升子序列 LIS
- 最长上升子序列(LIS)
- LIS最长上升子序列
- 最长上升子序列 LIS
- 最长上升子序列LIS
- LIS最长上升子序列
- 最长上升子序列LIS
- LIS 最长上升子序列
- 最长上升子序列LIS
- LIS(最长上升子序列)
- LIS 最长上升子序列
- lis 最长上升子序列
- LIS-最长上升子序列
- 最长上升子序列(LIS)
- 【学习摘记】马士兵HTML & CSS_课时1_html简单介绍和meta标签
- 六、高级进程管理
- Linux常用命令之date
- Native.js 原生方法-弹出对话框
- yii2 常用组件 -- 轮播
- LIS(即最长上升子序列)
- 工业机器人来了,是淘汰还是新生?
- adb 命令模拟按键事件
- frm表单-参数面板控件上加链接
- 设置TextView显示文本倾斜
- html 图片预览
- bzoj2243 [SDOI2011]染色(树链剖分,线段树求颜色段数)
- IE expo2017第十八届中国环博会-中国环博会(2017上海环保展)会刊(参展商名录)
- mapreduce 中文版 中文翻译