[LIS&LDS詳解]導(dǎo)彈攔截——洛谷-P1020

傳送門(mén)

導(dǎo)彈攔截


先介紹一下lower_bound和upper_bound嚼鹉;
lower_bound

??lower_bound可以二分找到數(shù)據(jù)序列中第一個(gè)大于等于x的數(shù)
??lower_bound默認(rèn)隊(duì)列中的數(shù)據(jù)是從小到大進(jìn)行排序的星虹,使用方法是lower_bound( begin, end, num)。假定對(duì)于a數(shù)組泰演,例如從[1呻拌,len)區(qū)間里查找第一個(gè)大于等于x的數(shù)lower_bound(a+1, a+1+len, x)葱轩。從[0睦焕,len)區(qū)間里查找第一個(gè)大于等于x的數(shù)lower_bound(a, a+len, x)。假如查到該數(shù)靴拱,就返回這個(gè)數(shù)的地址垃喊,如果查不到,則返回隊(duì)列的末尾end袜炕。那么我們?nèi)绾未_定他的下標(biāo)呢本谜,很簡(jiǎn)單,只需要減去數(shù)組的起始地址就能得到偏移量也就是他的下標(biāo)了偎窘。比如:

int k = lower_bound(a, a+len, x) - a;//k就是在數(shù)組a中第一個(gè)大于等于x的元素的下標(biāo)
... = a[k];  

??這里多插一句隊(duì)列的末尾在哪乌助,end在隊(duì)列中最后一個(gè)元素的后邊,如下表所示陌知,8個(gè)元素的隊(duì)列他托,end在第8個(gè)元素的后面:

1 2 3 4 5 6 7 8 end

對(duì)于下列這個(gè)具體的數(shù)據(jù)序列,長(zhǎng)度len = 8,找第一個(gè)大于等于3的元素仆葡。

A序列的序號(hào) 0 1 2 3 4 5 6 7
2 3 3 3 3 4 4 5

k = lower_bound(A,A+len,3) - A赏参; 此時(shí)k = 1,也就是該元素在序列中的位置沿盅。


??這是對(duì)于非下降序列來(lái)說(shuō)的把篓,可以找到第一個(gè)大于等于x的數(shù),那么對(duì)于非上升序列呢腰涧,我們?nèi)フ乙粋€(gè)小于等于x的數(shù)韧掩,這樣寫(xiě)就不對(duì)了,就需要更改lower_bound的默認(rèn)比較器窖铡,從其默認(rèn)的“<”改成“>”疗锐,這就需要我們手寫(xiě)一個(gè)比較器。

bool cmp(const int& a, const int& b){return a > b;}
int k = lower_bound(a, a + n, x, cmp) - a;

或者我們可以使用STL自帶的比較器万伤,greater<int>()提供了一個(gè)大于函數(shù)窒悔。

int k = lower_bound(a + 1, a + 1 + n, x, greater<int>() ) - a;

upper_bound

upper_bound與lower_bound最大的不同,upper_bound找到的是第一個(gè)\color{red}{大于}x的數(shù)敌买。再拿上邊的數(shù)組為例简珠,長(zhǎng)度len = 8,找第一個(gè)大于3的元素。

A序列的序號(hào) 0 1 2 3 4 5 6 7
2 3 3 3 3 4 4 5

k =upper_bound(A,A+len,3) - A聋庵; 此時(shí)k = 5膘融。


從另一種方面來(lái)解釋

??對(duì)于lower_bound(array, array+len, x),相當(dāng)于找到的是在保持序列仍有序時(shí)祭玉,x所能插入到原序列的最前的位置氧映。而對(duì)于upper_bound(array, array+len, x)是保持原序列有序時(shí),所能插入到原序列的最后的位置脱货。

以3為例,可插入到元素之前的位置

A序列的序號(hào) 0 1 2 3 4 5 6 7
2 3 3 3 3 4 4 5
可插入位置 \uparrow \uparrow \uparrow \uparrow \uparrow
lower upper

插入到上面帶箭頭的位置的元素之前岛都,都可以保證插入后的元素有序。


最長(zhǎng)上升子序列(LIS)

最長(zhǎng)下降子序列(LDS)

思路

AC代碼
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
#define maxn 1000100

int d[maxn], f[maxn], t[maxn];

int main(){
    int k = 0;
    while(scanf("%d", &d[k]) != EOF){
        k++;
    }

    int len = 1;
    f[len] = d[0];
    int len1 = 1;
    t[len1] = d[0];
    
    for(int i = 1; i < k; i++){
        if(d[i] <= f[len]){
            len++;
            f[len] = d[i];
        }else{
            int b = upper_bound(f+1, f+len+1, d[i], greater<int>()) - f;
            f[b] = d[i];
        }
        
        if(d[i] > t[len1]){
            len1++;
            t[len1] = d[i];
        }else{
            int b = lower_bound(t+1,t+len1+1,d[i])-t;
            t[b] = d[i];
        }
    }
    cout << len << endl;
    cout << len1 << endl;
    return 0;
}

非常簡(jiǎn)單的測(cè)試用代碼

#include<bits/stdc++.h>
using namespace std;

int main(){
    int a[] = {2, 3, 3, 3, 3, 4, 5, 6};
    int k1 = lower_bound(a, a+8, 3) - a;
    int k2 = upper_bound(a, a+8, 3) - a;
    cout << "lower_bound: " << k1 << endl;
    cout << "upper_bound: " << k2 << endl;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末振峻,一起剝皮案震驚了整個(gè)濱河市臼疫,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌扣孟,老刑警劉巖烫堤,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異凤价,居然都是意外死亡鸽斟,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)利诺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)富蓄,“玉大人,你說(shuō)我怎么就攤上這事立轧「穹啵” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵氛改,是天一觀的道長(zhǎng)帐萎。 經(jīng)常有香客問(wèn)我,道長(zhǎng)胜卤,這世上最難降的妖魔是什么疆导? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮葛躏,結(jié)果婚禮上澈段,老公的妹妹穿的比我還像新娘。我一直安慰自己舰攒,他們只是感情好败富,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著摩窃,像睡著了一般兽叮。 火紅的嫁衣襯著肌膚如雪芬骄。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,816評(píng)論 1 290
  • 那天鹦聪,我揣著相機(jī)與錄音账阻,去河邊找鬼。 笑死泽本,一個(gè)胖子當(dāng)著我的面吹牛淘太,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播规丽,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼蒲牧,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了嘁捷?” 一聲冷哼從身側(cè)響起造成,我...
    開(kāi)封第一講書(shū)人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎雄嚣,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體喘蟆,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡缓升,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蕴轨。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片港谊。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖橙弱,靈堂內(nèi)的尸體忽然破棺而出歧寺,到底是詐尸還是另有隱情,我是刑警寧澤棘脐,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布斜筐,位于F島的核電站,受9級(jí)特大地震影響蛀缝,放射性物質(zhì)發(fā)生泄漏顷链。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一屈梁、第九天 我趴在偏房一處隱蔽的房頂上張望嗤练。 院中可真熱鬧,春花似錦在讶、人聲如沸煞抬。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)革答。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蝗碎,已是汗流浹背湖笨。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蹦骑,地道東北人慈省。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像眠菇,于是被迫代替她去往敵國(guó)和親边败。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容