


下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、合唱隊(duì)形 解題報(bào)告<問(wèn)題描述> N位同學(xué)站成一排,音樂(lè)老師要請(qǐng)其中的(N-K)位同學(xué)出列,使得剩下的K位同學(xué)排成合唱隊(duì)形。 合唱隊(duì)形是指這樣的一種隊(duì)形:設(shè)K位同學(xué)從左到右依次編號(hào)為1,2,K,他們的身高分別為T(mén)1,T2,TK, 則他們的身高滿足T1<.<Ti>Ti+1>>TK(1<=i<=K)。 你的任務(wù)是,已知所有N位同學(xué)的身高,計(jì)算最少需要幾位同學(xué)出列,可以使得剩下的同學(xué)排成合唱隊(duì)形。- 輸入文件
2、160; 輸入文件chorus.in的第一行是一個(gè)整數(shù)N(2<=N<=100),表示同學(xué)的總數(shù)。第一行有n個(gè)整數(shù),用空格分隔,第i個(gè)整數(shù)Ti(130<=Ti<=230)是第i位同學(xué)的身高(厘米)。- 輸出文件 輸出文件chorus.out包括一行,這一行只包含一個(gè)整數(shù),就是最少需要幾位同學(xué)出列。- 樣例輸入8186 186 150 200 160 130 197 220- 樣例輸出4- 數(shù)據(jù)規(guī)模對(duì)于50的數(shù)據(jù),保證有n<=20;對(duì)于全部的數(shù)據(jù),保證有n<=100。<算法分析>動(dòng)態(tài)規(guī)劃。最基本
3、的想法是:枚舉中間最高的一個(gè)人,接著對(duì)它的左邊求最長(zhǎng)上升序列(注意序列中最高的同學(xué)不應(yīng)高過(guò)基準(zhǔn)),對(duì)右邊求最長(zhǎng)下降序列(同樣的,序列中最高的同學(xué)不應(yīng)高過(guò)基準(zhǔn))。時(shí)間復(fù)雜度為O(n3),算法實(shí)現(xiàn)起來(lái)也很簡(jiǎn)單。接著對(duì)這個(gè)算法進(jìn)行分析,我們不難發(fā)現(xiàn),假如還是基于枚舉一個(gè)同學(xué)的話,設(shè)Incsqi表示了1 - i的最長(zhǎng)上升序列,Decsqi表示了i - n的最長(zhǎng)下降序列,那么,Currenti = Incsqi + Decsqi - 1(兩個(gè)數(shù)組中i被重復(fù)計(jì)算了)那么,我們只需要先求好最長(zhǎng)上升和下降序列,然后枚舉中間最高的同學(xué)就可以了。<算法優(yōu)化>求最長(zhǎng)上升序列的經(jīng)典狀態(tài)轉(zhuǎn)移方程為:opti
4、 = maxoptj+1, 其中i<j<=n, 且listj>listi我們對(duì)狀態(tài)轉(zhuǎn)移方程稍微做一些修改:opti = maxopti+1, minj, recj>=listirecj = listi很明顯可以看出,在opti的尋找j的過(guò)程當(dāng)中,查詢序列是單調(diào)的,于是可以用二分法,就十分巧妙地在logn的時(shí)間內(nèi)找到指定的j,而問(wèn)題的總體復(fù)雜度為O(nlogn)。這樣,這個(gè)問(wèn)題的算法效率就得到了大幅度的提升,即便n是106,也可以輕松應(yīng)對(duì)。<代碼清單>#include <fstream>#include <cstring>using n
5、amespace std;ifstream fin("chorus.in");ofstream fout("chorus.out");const int maxn = 100;int n, amaxn;int incsqmaxn, decsqmaxn;void init() fin >> n;for (int i = 0; i < n; i +)fin >> ai;void LIncSeq()int i, low, high, mid, ans = 0;int solmaxn;for (i = 0; i < n; i
6、+) low = 1; high = ans;while (low <= high) mid = (low + high) >> 1;if (solmid < ai) low = mid + 1;else high = mid - 1;if (low > ans) ans +;sollow = ai;incsqi = ans;void LDecSeq()int i, low, high, mid, ans = 0;int solmaxn;for (i = 0; i < n; i +) low = 1; high = ans;while (low <=
7、high) mid = (low + high) >> 1;if (solmid > ai) low = mid + 1;else high = mid - 1;if (low > ans) ans +;sollow = ai;decsqi = ans;void work() int i, max = 0;LIncSeq();LDecSeq();for (i = 0; i < n; i +)if (incsqi + decsqi - 1 > max)max = incsqi + decsqi - 1;fout << n - max << endl;int main() init();work();return 0;&
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 合股開(kāi)餐廳合同范本
- 衛(wèi)生清潔合同范本
- 勞務(wù)派遣合同范本2003
- 個(gè)人供貨客戶合同范本
- 合股認(rèn)購(gòu)合同范本
- 合伙協(xié)議書(shū)范本合同范本
- 叉車工聘用合同范本
- 員工合同范例送水
- 傳單兼職人員合同范本
- 劇組財(cái)務(wù)合同范本
- 《色彩構(gòu)成——色彩基礎(chǔ)知識(shí)》PPT課件
- 煤礦供電系統(tǒng)及供電安全講座方案課件
- 綠色建筑及材料分析及案列
- 鍍層的結(jié)合力
- 霍尼韋爾DDC編程軟件(CARE)簡(jiǎn)介
- 實(shí)用中西醫(yī)結(jié)合診斷治療學(xué)
- 論《說(shuō)文解字》中的水文化
- 幕墻工程技術(shù)標(biāo)范本
- 德龍自卸車合格證掃描件(原圖)
- [國(guó)家公務(wù)員考試密押題庫(kù)]申論模擬925
- 初級(jí)電工教學(xué)大綱與教學(xué)計(jì)劃
評(píng)論
0/150
提交評(píng)論