数组中和最大的递增子序列
2015-10-25 22:29
309 查看
问题描述
Maximum Sum Increasing Subsequence
给定一个序列,找到这个序列的一个和最大的子序列,使得子序列的所有元素是升序的,且元素之间的相对位置不变(元素可以在原数组中不相邻,但是相对位置不变)
比如, LIS for { 10, 22, 9, 33, 21, 50, 41, 60, 80 } 是 255,LIS 是 {10, 22, 33, 50, 60, 80}.
参考数组中最长的升序子序列,这两道题类似,只是改变了一下条件,将“最长”变为了“和最大”,参考上篇文章的思路,用非递归方法实现:
Maximum Sum Increasing Subsequence
给定一个序列,找到这个序列的一个和最大的子序列,使得子序列的所有元素是升序的,且元素之间的相对位置不变(元素可以在原数组中不相邻,但是相对位置不变)
比如, LIS for { 10, 22, 9, 33, 21, 50, 41, 60, 80 } 是 255,LIS 是 {10, 22, 33, 50, 60, 80}.
参考数组中最长的升序子序列,这两道题类似,只是改变了一下条件,将“最长”变为了“和最大”,参考上篇文章的思路,用非递归方法实现:
int MSIS(int *arr,int n) { int *max_here = new int (); max_here[0] = arr[0]; int maxS = arr[0]; for(int i = 1; i<n; ++i) { for(int j = 0; j<i; ++j) { if(arr[j]<arr[i] && max_here[j]+arr[i]>max_here[i]) max_here[i] = max_here[j]+arr[i]; } if(max_here[i]>maxS) maxS = max_here[i]; } delete []max_here; return maxS; }
相关文章推荐
- 动易2006序列号破解算法公布
- ruby 数组使用教程
- Ruby中的数组和散列表的使用详解
- C#实现AddRange为数组添加多个元素的方法
- C#动态调整数组大小的方法
- Ruby实现的矩阵连乘算法
- C#插入法排序算法实例分析
- 详解Lua中的数组概念知识
- Perl中的列表和数组学习笔记
- 探索PowerShell (八) 数组、哈希表(附:复制粘贴技巧)
- C#中数组初始化与数组元素复制的方法
- C#交错数组用法实例
- 超大数据量存储常用数据库分表分库算法总结
- Linux Shell 数组建立及使用技巧
- PowerShell数组的一些操作技巧
- C#数据结构与算法揭秘二
- C#通过yield实现数组全排列的方法
- C#不重复输出一个数组中所有元素的方法
- C#冒泡法排序算法实例分析
- C#实现将数组内元素打乱顺序的方法