版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
1、問題求解與程序設(shè)計第五講 問題抽象,李文新2004.2 – 2004.6,內(nèi)容提要,Binary codes - 1147討論 – 1063 作業(yè) – 1063,問題描述,給定一個N位的二進制串b1 b2 … bN-1 bN將該串做旋轉(zhuǎn),即將b1移到bN后面,得到一個新的二進制串:b2 … bN-1 bN b1,問題描述,對新的二進制串再做旋轉(zhuǎn),得二進制串b3 b4 … bN-1 bN
2、 b1 b2重復(fù)旋轉(zhuǎn)操作操作,可得N個二進制串,對這N個串排序,可得一個N*N的矩陣,問題描述,例如:1 0 0 0 1 0 0 0 1 11 1 0 0 00 0 1 1 00 1 1 0 0,,,,,問題描述,對它們做排序,得矩陣0 0 0 1 10 0 1 1 0 0 1 1 0 0
3、1 0 0 0 1 1 1 0 0 0,問題描述,問:給定這種矩陣的最后一列,求出矩陣的第一行。對于上面的例子,給出 1 0 0 1 0,要你的程序輸出 0 0 0 1 1。,問題描述,輸入文件名:bincode.in第一行有一個整數(shù) N 表示二進制串的長度第二行有N個整數(shù),表示矩陣最后一列從上到下的數(shù)值。,問題描述,輸出文件名:bincode.out第一行包括N個整數(shù),表
4、示矩陣第一行從左到右的數(shù)值。,問題描述,輸入樣例bincode.in51 0 0 1 0,問題描述,輸出樣例bincode.out0 0 0 1 1,問題描述,限制1 <= N <= 1000,解法一 猜測法,計算輸入列中包含 0 的個數(shù) I生成輸出行:前I個為0,后N-I個為1思路:因為矩陣按字母序排序,所以0應(yīng)該在前面。?該算法不能保證正確,但對樣例正確?,解法二 窮舉法,生成
5、一個長度為N的全0序列按規(guī)則將其旋轉(zhuǎn)生成N*N矩陣如果最后一列與輸入相同,則輸出開始的序列。按字母序生成下一個長度為N的二進制序列,goto 2.,解法二 窮舉法,顯然這一算法不是最優(yōu)的,但是它是正確的,因為它窮舉了全部可能。,解法三 迭代法,初始化一個N行,最開始是0列的工作矩陣.將輸入列放在當(dāng)前工作矩陣左邊,對行排序.如果矩陣列數(shù)小于N, goto 2.輸出第一行,解法三 迭代法,例子 (輸入10010
6、) 010 00 100 0000 000 00 000 0010 000 01 001 0111 111 10 110 1000 101 11 011 110,解法三 迭代法,例子 (輸入10010)0001000 0001 10001 0001100010001 0011 00011 001100011
7、0011 0110 00110 0110011001100 1000 11000 1000101100110 1100 01100 11000輸出:00011,解法三 迭代法,分析該算法所需數(shù)時間是>O(N3)N次迭代,每次要對一個N*N的矩陣排序,解法三 迭代法,證明該算法的本質(zhì)是逐一構(gòu)造矩陣的前 I 列對于I=1,重新排序后顯然成立對于I<N,如果
8、前I列就是矩陣的前I列,那么把最后一列加到前面,從序列的順序來說,是正確的,重新對這I+1列排序保證了行順序的正確性。,解法三 迭代法,分析一個值得注意的現(xiàn)象是:每次排序總是把開頭是0的行按原來的先后次序移到前面,而把開頭是1的行按原來的先后次序移到后面。,解法四 線性算法,算法描述:1.計算輸入列中0和1的個數(shù),并用它們形成第一列.,解法四 線性算法,2. 生成一個Next數(shù)組,使得數(shù)組中的i個0指向最后一
9、列第i個0的行數(shù),數(shù)組中的第j個1指向最后一列第j個1的行數(shù).,解法四 線性算法,3. 從第1行開始,按照Next指引的順序 – 從k到Next[k], 每次把該行最后一列的數(shù)字取出生成第一行的相應(yīng)數(shù)字。,解法四 線性算法,例如 輸入 10010有3個0,2個1,所以第1列一定是00011,解法四 線性算法,例如 輸入 100102.生成Next數(shù)組Next
10、10122003300541115104,,,,,,解法四 線性算法,例如 輸入 10010 Next 235143.沿著Next,根據(jù) 輸入列,生成第一行0 0 0 1 1,解法四 線性算法,證明對于序列(1) b1 b2 … bN-1 bN,左旋一位變成(2) b2 … bN-1 bN b1 ,
11、我們只要知道(1)左旋后得到的(2)在矩陣中是哪一行,就可以根據(jù)該行第一列的值得到 b2,依次類推得到b3 , b4 , …,解法四 線性算法,證明假設(shè)矩陣中兩行都以0開始,則它們左旋后,前后次序不變,所以在矩陣中以0開始的第1行,它的左旋后的序列在最后一列的第一個0的行。對1開始的行有同樣的性質(zhì)。,解法四 線性算法,證明例如 1 0 0 0 1 1 第1,2,3行以0 20 0
12、 1 1 0 開始,左旋后0 30 1 1 0 0 到最后1列,但 41 0 0 0 1 前后順序不變, 51 1 0 0 0 所以是2,3,5,解法四 線性算法,證明該算法就是利用了這一性質(zhì),根據(jù)第1列和最后1列,直接算出第1行。,測試數(shù)據(jù),20 組100 位 全1100位 全0100位 01…01
13、1000位 0…01…1,5位,10位,15位的小數(shù)據(jù)長度為300-1000的隨機序列 13個,算法分析初步,算法 – 解決問題的計算方法衡量算法的標(biāo)準(zhǔn):正確性時間效率空間效率清晰性 – 實現(xiàn)的簡單性最優(yōu)性,算法分析初步,正確性完整的算法包括輸入、輸出和從輸入到輸出的處理過程。驗證算法的正確性是指證明該算法可以從輸入經(jīng)過算法所描述的過程一定可以到達預(yù)定的輸出。定理證明正確性簡單驗證+幾個樣例驗證,算法分析
溫馨提示
- 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 問題求解與程序設(shè)計
- 漓江學(xué)堂程序設(shè)計與問題求解期末考試參考程序
- 齒輪變摩擦三維接觸問題有限元混合法求解及程序設(shè)計.pdf
- 并行程序設(shè)計模型若干問題研究.pdf
- 算法與程序設(shè)計
- 算法與程序設(shè)計
- vb程序設(shè)計例題-程序改錯程序填空程序設(shè)計
- 編程解決問題之程序設(shè)計語言c語言
- 智能手機個性化程序設(shè)計問題研究
- 第1單元程序與程序設(shè)計
- 第1單元程序與程序設(shè)計
- 程序設(shè)計教案 程序設(shè)計——數(shù)據(jù)結(jié)構(gòu)
- c語言程序設(shè)計實驗與習(xí)題指導(dǎo)課后程序設(shè)計答案
- 若干工程問題的有限元建模及程序設(shè)計.pdf
- 問題探究—互動式教學(xué)在程序設(shè)計課堂的實踐
- 規(guī)劃問題求解與excel應(yīng)用
- 最簡單的c程序設(shè)計――順序程序設(shè)計
- 自動程序設(shè)計
- 894程序設(shè)計
- 書名《編程解決問題之程序設(shè)計語言(c語言)》 《編程
評論
0/150
提交評論