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

查找最长递增子序列

时间:2014-07-21 11:23:15      阅读:185      评论:0      收藏:0      [点我收藏+]

标签:dp   阅读   

一般情况:

#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 <algorithm>
#include <string.h>
using namespace std;
int d[1005],p[1005],n;
int LIS()
{
    int i,j,sta,end,mid,l;
    for(i=2;i<=n;i++)  
        {  
            sta=1;  
            end=l+1;  
            while(sta<end)  
            {  
                mid=(sta+end)/2;  
                if(d[i]<=p[mid])  
                    end=mid;  
                else  
                    sta=mid+1;  
            }  
            p[end]=d[i];  
            if(end==l+1)  
                l++;  
        }  
    return l;
}



查找最长递增子序列

标签:dp   阅读   

原文地址:http://blog.csdn.net/jiangx1994/article/details/38013583

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