用DP解决最长子序列问题
2017-01-03 19:20
218 查看
“最长子序列”问题(即有限空间内,满足一定条件的最长顺序子序列)
一般的解法:用DP表来记录以当前节点为末节点的序列的解,这样可以固定问题的一端,以下以两个例子来讲子序列问题。
1.在一个整数数组中,找到最长的递增子序列。
分析:用DP表来记录以当前节点为末节点的序列的最大长度。maxLength[i]=max{maxLength[k],k=0~i-1and array[i]>array[k]}
参考解答:
#include <iostream>
#include <vector>
using namespace std;
int LongestIncreasingSubsquence(int arr[],int n)
{
vector<int> maxLength(n,1);
int global_max=0;
for(int i=0;i<n;i++)
for(int j=0;j<i;j++)
if(arr[i]>arr[j]&&maxLength[j]+1>maxLength[i])
maxLength[i]=maxLength[j]+1;
for(int i=0;i<n;i++)
if(global_max<maxLength[i])
global_max=maxLength[i];
return global_max;
}
int main()
{
int n;
cin>>n;
int arr
;
int sum=0;
for(int i=0;i<n;i++)
cin>>arr[i];
sum=LongestIncreasingSubsquence(arr,n);
cout<<sum;
return 0;
}
2.在一个数组中找出一个连续的和最大的子数组
分析:只需要观察以当前节点为末节点的可能的最大sum,并使用max_sum记录。
sum[i]=max{sum[i-1]+arr[i],arr[i]}
参考代码:
#include "stdafx.h"
#include<iostream>
using namespace std;
int maxSum(int arr[],int n)
{
int max_sum=arr[0];
int sum=arr[0];
for(int i=1;i<n;i++)
{
if(sum+arr[i]>arr[i])
{
sum=sum+arr[i];
}else{sum=arr[i];}
if(max_sum<sum)
max_sum=sum;
}
return max_sum;
}
int _tmain(int argc, _TCHAR* argv[])
{
int arr[]={1,-2,3};
int max_sum=maxSum(arr,3);
cout<<max_sum;
system("pause");
return 0;
}
一般的解法:用DP表来记录以当前节点为末节点的序列的解,这样可以固定问题的一端,以下以两个例子来讲子序列问题。
1.在一个整数数组中,找到最长的递增子序列。
分析:用DP表来记录以当前节点为末节点的序列的最大长度。maxLength[i]=max{maxLength[k],k=0~i-1and array[i]>array[k]}
参考解答:
#include <iostream>
#include <vector>
using namespace std;
int LongestIncreasingSubsquence(int arr[],int n)
{
vector<int> maxLength(n,1);
int global_max=0;
for(int i=0;i<n;i++)
for(int j=0;j<i;j++)
if(arr[i]>arr[j]&&maxLength[j]+1>maxLength[i])
maxLength[i]=maxLength[j]+1;
for(int i=0;i<n;i++)
if(global_max<maxLength[i])
global_max=maxLength[i];
return global_max;
}
int main()
{
int n;
cin>>n;
int arr
;
int sum=0;
for(int i=0;i<n;i++)
cin>>arr[i];
sum=LongestIncreasingSubsquence(arr,n);
cout<<sum;
return 0;
}
2.在一个数组中找出一个连续的和最大的子数组
分析:只需要观察以当前节点为末节点的可能的最大sum,并使用max_sum记录。
sum[i]=max{sum[i-1]+arr[i],arr[i]}
参考代码:
#include "stdafx.h"
#include<iostream>
using namespace std;
int maxSum(int arr[],int n)
{
int max_sum=arr[0];
int sum=arr[0];
for(int i=1;i<n;i++)
{
if(sum+arr[i]>arr[i])
{
sum=sum+arr[i];
}else{sum=arr[i];}
if(max_sum<sum)
max_sum=sum;
}
return max_sum;
}
int _tmain(int argc, _TCHAR* argv[])
{
int arr[]={1,-2,3};
int max_sum=maxSum(arr,3);
cout<<max_sum;
system("pause");
return 0;
}
相关文章推荐
- 公主和王子能在一起多久的问题+dp+最长公共子序列转最长子序列。
- hdu 1160 DP 最长子序列问题
- 动态规划解决最长子序列问题
- POJ 1952 BUY LOW BUY LOWER 【DP】最长降序子序列及其计数问题
- POJ1631 Bridging signals(DP类似最长子序列)
- dp解决最大子矩阵问题
- NYOJ 题目17 单调递增最长子序列 (DP)
- NYOJ - 单调递增最长子序列(经典dp)
- 解决发送端与接收端包序列不一致问题
- NYOJ 17 单调递增最长子序列(经典dp)
- 动态规划解最长子序列问题
- 利用“自定义序列”解决排序问题
- 未解决的dp问题
- DP问题之最长非降子序列
- 最长子序列和问题
- 最长子序列问题之系列一
- 关于C++随机数生成中种子值设置的一点总结,解决随机数序列重复问题
- 九度笔记之 1342:寻找最长合法括号序列II(25分)-给括号当红娘,解决最长合法字符串问题
- nyoj 214 单调递增子序列问题(dp)
- hdu--1231--最长子序列(DP)