码迷,mamicode.com
首页 > 其他好文 > 详细

最长上升子序列(模板)

时间:2014-06-24 17:18:33      阅读:188      评论:0      收藏:0      [点我收藏+]

标签:模板   lis   

转载请注明出处:http://blog.csdn.net/u012860063


一般的情况下:

#include <stdio.h>
#include <algorithm>
#include <string.h>
using namespace std;

int a[1005],dp[1005],n;

int LIS()
{
    int i,j,ans,m;
    dp[1] = 1;
    ans = 1;
    for(i = 2;i<=n;i++)
    {
        m = 0;
        for(j = 1;j<i;j++)
        {
            if(dp[j]>m && a[j]<a[i])
				m = dp[j];
        }
        dp[i] = m+1;
        if(dp[i]>ans)
			ans = dp[i];
    }
    return ans;
}
二分优化:

#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;

int a[40005],dp[40005],n;

int bin(int size,int k)
{
    int l = 1,r = size;
    while(l<=r)
    {
        int mid = (l+r)/2;
        if(k>dp[mid])
            l = mid+1;
        else
            r = mid-1;
    }
    return l;
}

int LIS()
{
    int i,j,ans=1;
    dp[1] = a[1];
    for(i = 2; i<=n; i++)
    {
        if(a[i]<=dp[1])
            j = 1;
        else if(a[i]>dp[ans])
            j = ++ans;
        else
            j = bin(ans,a[i]);
        dp[j] = a[i];
    }
    return ans;
}



最长上升子序列(模板),布布扣,bubuko.com

最长上升子序列(模板)

标签:模板   lis   

原文地址:http://blog.csdn.net/u012860063/article/details/34086819

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!