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

最长上升子序列[LIS]

时间:2016-08-11 06:13:07      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:

算法原理很简单,不再赘述,这里贴一个函数模板,传入的参数为序列首尾元素的指针。

template<typename T> int LIS_nlogn(T * s, T * e)
{
    if (s > e) return 0;
    T g[e - s + 5];
    int ret = 0;
    memset(g, 0, sizeof(g));
    for (T * i = s; i <= e; i++)
    {
        if (g[ret] < (*i))
        {
            g[++ret] = (*i);
            continue;
        }
        int l = 1, r = ret, mid;
        while (l < r)
        {
            mid = (l + r) >> 1;
            if ((*i) < g[mid]) r = mid;
            else l = mid + 1;
        }
        g[l] = (*i);
    }
    return ret;
}

 

最长上升子序列[LIS]

标签:

原文地址:http://www.cnblogs.com/dramstadt/p/5759426.html

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