版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、動態(tài)規(guī)劃上機習(xí)題,臧家瑞,地板覆蓋(簡),用2*1的地板塊覆蓋3*n的地板有多少種方案? 如下圖是一個覆蓋的例子:,,。。。。。。上下翻轉(zhuǎn)也可以——乘以2,動態(tài)轉(zhuǎn)移方程,石子游戲,現(xiàn)有4堆石子,兩個人輪流取石子,他們有n種可能的取法,取法表示從第1堆取A1個石子,從第2堆中取B1個,第3堆取C1個,第4堆取D1個.如果取的時候某一堆的石子數(shù)比所要取的石子數(shù)要少,則這種取法是不可行的.取到最后沒有可行取法的人就算輸了. 現(xiàn)給出4堆
2、石子的石子數(shù)目以及n種取法,請問如果兩個人都采用最優(yōu)取法,先取的人是贏還是輸.,數(shù)據(jù)結(jié)構(gòu),每一種石子數(shù)為一個狀態(tài)state,每個狀態(tài)都記錄先手回合的先手輸贏offen和后手回合的先手輸贏defen.struct state {bool offen;//先手回合時,1:先手贏, 0:先手輸boot defen;//后手回合時,1:先手贏, 0:先手輸}struct state st[31][31][31][31];//所
3、有狀態(tài)記錄n種取法的數(shù)組struct remove {int a, b, c, d;} rm[10];,動態(tài)轉(zhuǎn)移方程,初始化,多邊形游戲,多邊形游戲是一種在一個具有n個頂點的多邊形上進(jìn)行的游戲。如圖1是一個n=4對應(yīng)多邊形,每個頂點上都有一個整數(shù),每條邊都有一個運算符+或者*,所有邊按從1到n進(jìn)行編號。,多邊形游戲,游戲都首先移除一條邊,接下來可以進(jìn)行如下操作:選擇一條邊E和與之相關(guān)聯(lián)的點V1和V2,用一個新的點替換它們,
4、新點上的整數(shù)為V1,V2上的整數(shù)用E上的操作符運算后的結(jié)果。 沒有邊時游戲結(jié)束,游戲得分就是最后剩下的那個頂點上的整數(shù)。 對于圖1中的多邊形,如果游戲者首先去掉3,然后依次去掉1、4、2,最后得分將是0。,多邊形游戲,多邊形游戲,關(guān)于輸入 輸入第一行是一個正整數(shù)n(3<=n<=50),表示多邊形的邊數(shù)。接下來一行是這個多邊形的描述,包含n條邊和n個頂點,加號邊用t表示,乘號邊用x表示,頂點用頂點上標(biāo)的整數(shù)表示,輸入按
5、照邊的編號從1到n的順序給出。 關(guān)于輸出 第一行輸出可能得到的最高分。 第二行輸出一些邊的列表,只有第一步移除的邊在這個列表中才可能得到最高分。每條邊都用這個邊上的編號表示,列表必須是升序的。,狀態(tài),max[i][j]表示順時針方向從邊i的終點連續(xù)j條邊進(jìn)行計算所能得到的最高分min[i][j]表示順時針方向從邊i的終點連續(xù)j條邊進(jìn)行計算所能得到的最低分由于環(huán)狀結(jié)構(gòu),第n條邊及第0條邊edge[i]表示邊i上的運算符wei
6、ght[i]表示邊i的終點的權(quán)值問題所求即為max[i][n-1],(i=0,1,2,…n-1) 中的最大值,動態(tài)轉(zhuǎn)移方程,基因串,基因串是由一串有限長度的基因所組成的,其中每一個基因都可以用26個英文大寫字母中的一個來表示,不同的字母表示不同的基因類型。一個單獨的基因可以生長成為一對新的基因,而可能成長的規(guī)則是通過一個有限的成長規(guī)則集所決定的。每一個成長的規(guī)則可以用三個大寫英文字母A1A2A3來描述,這個規(guī)則的意思是基因A1可以成長
7、為一對基因A2A3。 用大寫字母S來表示一類稱作超級基因的基因,因為每一個基因串都是由一串超級基因根據(jù)給出的規(guī)則所成長出來的。 請寫一個程序,讀入有限條成長的規(guī)則和一些我們想要得到的基因串,然后對于每個基因串,判斷它是否可以由一個有限長度的超級基因串成長得出。如果可以,給出可成長為該基因串的最短超級基因串的長度。,準(zhǔn)備,集合reduc[i][j]表示從第i個基因開始長度為j的基因串可以歸約成的單個基因的集合。Gstr為目標(biāo)基因串
8、reduc[i][1]={Gstr[i]};reduc[i][j] = U{reduc[i][k] · reduc[i+k][j-k]} ,如果reduc[i][k]中存在基因A,reduc[i+k][j-k]中存在基因B,滿足C->AB則C ? U{reduc[i][k] · reduc[i+k][j-k]} 全集E={A,B,C,…,Z},可以用一個整型變量作集合的bitmap,動態(tài)歸劃,short[i
9、][j]表示從第i個基因開始長度為j的基因串最少可以歸約成的超級基因數(shù)動態(tài)轉(zhuǎn)移方程short[i][j] = MIN { 1 + short[i+k][j-k]},k滿足reduc[i][k]中含有S,k=1,2,….j初始化short[i][j] = +∞,short[i][0]=0,象棋比賽,你需要從你的棋牌協(xié)會中選出30人參加一場團(tuán)隊邀請賽,比賽共30場,15人先手持紅,另15人后手持黑.每個人先手和后手的能力值有所不
10、同,現(xiàn)在你需要從你的協(xié)會里選出這30人,使得其中15人持紅的能力值與另外15人持黑的能力值的總和盡可能大.,動態(tài)轉(zhuǎn)移方程,ability[i][j][k]:在i個人中選j個人執(zhí)紅,k個人執(zhí)黑所得能力值總值的最大值,初始化為0.,地板覆蓋,用1*2的地板磚覆蓋n*m的地板有多少種方案呢?,,如果n與m全是奇數(shù),0種方案每一行用一個bitvector表示,從上一行繼承下來一個格子被覆蓋,則該位標(biāo)記為1,否則標(biāo)記為0,如下圖的bitvect
11、or即為0010011011,,從一行到下一行可以表示為狀態(tài)的轉(zhuǎn)化,如0010011011可以達(dá)到1100000100(如圖),還可以達(dá)到0000000100,0001100100,1101100100,,用整型變量來表示這些bitvector狀態(tài)。判斷狀態(tài)i是否可達(dá)狀態(tài)j,狀態(tài)1111…1記為f,i?(~i)&f若j&((~i)&f)==j,且(~i)&f - j中所有的1都可以按相臨位置兩兩綁定
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 人力資源規(guī)劃上機例題
- 動態(tài)規(guī)劃習(xí)題
- 交通規(guī)劃上機報告-交通生成預(yù)測、交通分布預(yù)測、交通方式分擔(dān)預(yù)測實驗
- 上機練習(xí)題
- 上機練習(xí)題
- 上機指導(dǎo) 習(xí)題答案
- 微觀上機測試習(xí)題
- matlab上機習(xí)題3
- vfp上機練習(xí)題
- 設(shè)計示范和上機習(xí)題
- vfp上機習(xí)題(附答案)
- matlab上機習(xí)題一-解答
- 上機習(xí)題3、4、5
- vb上機練習(xí)題
- spss上機習(xí)題附答案
- photoshop上機練習(xí)題
- 動態(tài)規(guī)劃練習(xí)題及解答1
- java上機程序復(fù)習(xí)題
- 網(wǎng)頁制作上機練習(xí)題
- java上機實踐練習(xí)題
評論
0/150
提交評論