首页 > 其他 > 详细

查找最长递增子序列

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

一般情况:

#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;
}



查找最长递增子序列

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

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!