求最長(zhǎng)升序(降序)子數(shù)列

? ? ??第一次接觸到求最長(zhǎng)升序(降序)子數(shù)列這個(gè)知識(shí)是在導(dǎo)彈攔截問題中,導(dǎo)彈攔截問題如下:

題意:一種導(dǎo)彈攔截系統(tǒng)的第一發(fā)炮彈能夠到達(dá)任意的高度观谦,但是以后每一發(fā)炮彈都不能高于前一發(fā)的高度。某天,雷達(dá)捕捉

到敵國(guó)的導(dǎo)彈來襲兄一。由于該系統(tǒng)還在試用階段,所以只有一套系統(tǒng)识腿,因此有可能不能攔截所有的導(dǎo)彈出革。輸入導(dǎo)彈依次飛來的高

度,計(jì)算這套系統(tǒng)最多能攔截多少導(dǎo)彈覆履?

分析:

? ? ?因?yàn)槊恳淮螖r截彈道的發(fā)射都不能高于前一發(fā)攔截導(dǎo)彈的高度蹋盆,敵國(guó)導(dǎo)彈按照順序襲來,此時(shí)我們需要觀察敵國(guó)所有導(dǎo)彈的高度硝全,

設(shè)定最佳的第一枚攔截導(dǎo)彈高度栖雾,盡可能的攔截更多的導(dǎo)彈。

例如敵國(guó)導(dǎo)彈共6顆伟众,高度分別為:389析藕;207;155凳厢;300账胧;299;170先紫;158治泥;65

分析可知當(dāng)我們最多可以攔截到六顆導(dǎo)彈(389;300遮精;299居夹;172败潦;158;65)即就是求出最長(zhǎng)子不升序子序列准脂。


求解求最長(zhǎng)升序(降序)子數(shù)列:

我們使用動(dòng)態(tài)規(guī)劃的思想來解決這個(gè)問題劫扒,用數(shù)組a[n]來存儲(chǔ)原數(shù)組,在生成一個(gè)數(shù)組b[n]狸膏,b[i]來記錄在前i個(gè)數(shù)據(jù)中存在的最長(zhǎng)升序子序列的長(zhǎng)度沟饥,b[i]也可以理解為:在前i個(gè)數(shù)據(jù)中以b[i]結(jié)尾所有子序列中最長(zhǎng)子序列的長(zhǎng)度。


最長(zhǎng)升序子序列c++代碼如下(降序代碼改動(dòng)在注釋中給出):

#include <iostream>

using namespace std;

int main(){? ??

int n; ? ?//數(shù)據(jù)個(gè)數(shù)

int answer=0;? ??

cout << "請(qǐng)輸入數(shù)組長(zhǎng)度:" << endl; ? ?

cin>>n; ??

int a[n]; ? // 儲(chǔ)存數(shù)據(jù)數(shù)組

int b[n]; ?// ?動(dòng)態(tài)規(guī)劃輔助數(shù)組

cout << "請(qǐng)錄入數(shù)組數(shù)據(jù)" << endl;? ??

for(int i=0;i<n;++i)

{

cin>>a[i];? ? ? ??

b[i]=1; ? ?// 每個(gè)數(shù)據(jù)都至少可以構(gòu)成長(zhǎng)度為一的子序列

}

for(int i=1;i<n;++i) // 第一個(gè)數(shù)據(jù)子序列長(zhǎng)度只可能為1湾戳,所以從第二個(gè)數(shù)據(jù)開始掃描

{

? ? for(int j=0;j<i;++j) //檢查每個(gè)數(shù)前面所有數(shù)據(jù)

? ? {

? ? ? ? if(a[j]<a[i]) //若a[j]<a[i]贤旷,則有可能使以a[i]結(jié)尾的升序子序列長(zhǎng)度加(!院塞!求降序是用>號(hào))

? ? ? ? {

? ? ? ? if(b[j]+1>b[i]) //遍歷之前所有數(shù)據(jù)遮晚,找出b[i]的最大值

? ? ? ? ? ? {

? ? ? ? ? ? b[i]=b[j]+1;

? ? ? ? ? ? }

? ? ? ? }

? ? }

}

for(int i=0;i<n;++i) //在數(shù)組b中找出最大的b[i],即就是最長(zhǎng)的升序子序列長(zhǎng)度性昭。

{

if(b[i]>answer)

? ? {

? ? answer=b[i];

? ? }

}

cout<<"最長(zhǎng)升序子序列的長(zhǎng)度為:"<<answer<<endl;

return 0;

}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末拦止,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子糜颠,更是在濱河造成了極大的恐慌汹族,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,544評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件其兴,死亡現(xiàn)場(chǎng)離奇詭異顶瞒,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)元旬,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門榴徐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人匀归,你說我怎么就攤上這事坑资。” “怎么了穆端?”我有些...
    開封第一講書人閱讀 162,764評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵袱贮,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我体啰,道長(zhǎng)攒巍,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,193評(píng)論 1 292
  • 正文 為了忘掉前任荒勇,我火速辦了婚禮柒莉,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘沽翔。我一直安慰自己兢孝,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評(píng)論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著西潘,像睡著了一般卷玉。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上喷市,一...
    開封第一講書人閱讀 51,182評(píng)論 1 299
  • 那天相种,我揣著相機(jī)與錄音,去河邊找鬼品姓。 笑死寝并,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的腹备。 我是一名探鬼主播衬潦,決...
    沈念sama閱讀 40,063評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼植酥!你這毒婦竟也來了镀岛?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,917評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤友驮,失蹤者是張志新(化名)和其女友劉穎漂羊,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體卸留,經(jīng)...
    沈念sama閱讀 45,329評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡走越,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了耻瑟。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片旨指。...
    茶點(diǎn)故事閱讀 39,722評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖喳整,靈堂內(nèi)的尸體忽然破棺而出谆构,到底是詐尸還是另有隱情,我是刑警寧澤算柳,帶...
    沈念sama閱讀 35,425評(píng)論 5 343
  • 正文 年R本政府宣布低淡,位于F島的核電站,受9級(jí)特大地震影響瞬项,放射性物質(zhì)發(fā)生泄漏蔗蹋。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評(píng)論 3 326
  • 文/蒙蒙 一囱淋、第九天 我趴在偏房一處隱蔽的房頂上張望猪杭。 院中可真熱鬧,春花似錦妥衣、人聲如沸皂吮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蜂筹。三九已至需纳,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間艺挪,已是汗流浹背不翩。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留麻裳,地道東北人口蝠。 一個(gè)月前我還...
    沈念sama閱讀 47,729評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像津坑,于是被迫代替她去往敵國(guó)和親妙蔗。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評(píng)論 2 353

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