标签:子序列 子串 公共祖先 动态规划 common prefix
#include<iostream>
#include<vector>
using namespace std;
int DoubleEndLIS(vector<int> data)//当然也可以使用O(nlogn)的算法
{
int length = data.size(),i,j,res = length;
if(length == 0)return 0;
vector<int> B(length,1),C(length,1);
for(i = 0;i < length;++i)//从左向右
{
for(j = 0;j < i;++j)
{
if(data[j] < data[i] && B[j]+1 > B[i])B[i] = B[j]+1;
}
}
for(i = length-1;i >= 0;--i)//从右向左
{
for(j = length-1;j > i;--j)
{
if(data[j] < data[i] && C[j]+1 > C[i])C[i] = C[j]+1;
}
}
for(i = 0;i < length;++i)
{
if(length - B[i] - C[i] + 1 < res)res = length - B[i] - C[i] + 1;
}
return res;
}
int main()
{
int n,i;
while(cin >> n)
{
vector<int> data(n);
for(i=0;i < n;++i)cin >> data[i];
cout << DoubleEndLIS(data) << endl;
}
}标签:子序列 子串 公共祖先 动态规划 common prefix
原文地址:http://blog.csdn.net/fangjian1204/article/details/38680907