第一篇:2015版數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)題目(2015年版):
(1-6題必做,做完9題以上可參評(píng)優(yōu)秀)
1、日程計(jì)劃管理系統(tǒng)(必做)(線性表)[問題描述]
設(shè)計(jì)一個(gè)程序,記錄并管理日程計(jì)劃。[基本要求](1)日程計(jì)劃信息包括日程計(jì)劃ID號(hào),日程計(jì)劃開始日期和時(shí)間,日程計(jì)劃結(jié)束日期和時(shí)間,日程計(jì)劃名,日程計(jì)劃參與人員,日程計(jì)劃地點(diǎn),日程計(jì)劃提醒日期和時(shí)間。
(2)采用雙向循環(huán)鏈表表示日程計(jì)劃信息。采用三個(gè)雙向循環(huán)鏈表:
第一個(gè)雙向循環(huán)鏈表表示未開始的日程計(jì)劃信息,按照日程計(jì)劃開始日期和時(shí)間先后排序;
第二個(gè)雙向循環(huán)鏈表表示正在進(jìn)行的日程計(jì)劃信息(可以多項(xiàng)計(jì)劃同時(shí)進(jìn)行),按照日程計(jì)劃開始日期和時(shí)間先后排序;
第三個(gè)雙向循環(huán)鏈表表示已過期的日程計(jì)劃信息,按照日程計(jì)劃開始的日期和時(shí)間倒序排序。
(3)日程計(jì)劃信息采用文件方式輸入。
日程計(jì)劃信息信息示例如下,每條信息一行:
日程計(jì)劃ID號(hào) 開始日期 開始時(shí)間 結(jié)束日期 結(jié)束時(shí)間 計(jì)劃名 ?
20141011001;2014-10-11;8:00:00;2014-10-11;10:00:00;數(shù)據(jù)結(jié)構(gòu)上課;張三;6202;2014-10-11;7:40:00
(4)要求模擬數(shù)據(jù)中日程計(jì)劃信息至少30條以上。(5)實(shí)現(xiàn)以下功能:
a.輸入新的計(jì)劃;
b.根據(jù)當(dāng)前時(shí)間查詢未開始的計(jì)劃,包括當(dāng)天未開始的計(jì)劃、本周或本月未開始的計(jì)劃;
c.查詢并輸出已結(jié)束的計(jì)劃; d.查詢正在進(jìn)行的計(jì)劃;
e.根據(jù)當(dāng)前時(shí)間,輸出正提醒即將開始的計(jì)劃。
(6)可在此要求基礎(chǔ)上進(jìn)行功能擴(kuò)展,比如周期性重復(fù)計(jì)劃的設(shè)臵和提醒等。
2、算術(shù)表達(dá)式求值(必做)(棧)[問題描述]
一個(gè)算術(shù)表達(dá)式是由操作數(shù)(operand)、運(yùn)算符(operator)和界限符(delimiter)組成的。假設(shè)操作數(shù)是正實(shí)數(shù),運(yùn)算符只含加減乘除等四種運(yùn)算符,界限符有左右括號(hào)和表達(dá)式起始、結(jié)束符“#”,如:#(7+15)*(23-28/4)#。引入表達(dá)式起始、結(jié)束符是為了方便。編程利用“算符優(yōu)先法”求算術(shù)表達(dá)式的值。[基本要求](1)從鍵盤或文件讀入一個(gè)合法的算術(shù)表達(dá)式,輸出正確的結(jié)果。(2)顯示輸入序列和棧的變化過程。
(3)考慮算法的健壯性,當(dāng)表達(dá)式錯(cuò)誤時(shí),要給出錯(cuò)誤原因的提示。(4)實(shí)現(xiàn)非整數(shù)的處理(可選功能)。
3、Huffman編碼與解碼(必做)(Huffman編碼、二叉樹)[問題描述] 對(duì)一篇英文文章(大于2000個(gè)英文字符),統(tǒng)計(jì)各字符出現(xiàn)的次數(shù),實(shí)現(xiàn)Huffman編碼,以及對(duì)編碼結(jié)果的解碼。[基本要求](1)輸出每個(gè)字符出現(xiàn)的次數(shù)和編碼,其中求最小權(quán)值要求用堆實(shí)現(xiàn)。
(2)在Huffman編碼后,要將編碼表和英文文章編碼結(jié)果保存到文件中,編碼結(jié)果必須是二進(jìn)制形式,即0 1的信息用比特位表示,不能用字符’0’和’1’表示。(3)提供讀編碼文件生成原文件的功能。
4、關(guān)鍵路徑問題(必做)(圖)[問題描述] 設(shè)計(jì)并實(shí)現(xiàn)關(guān)鍵路徑的一種應(yīng)用。[基本要求](1)實(shí)現(xiàn)拓?fù)渑判蚝完P(guān)鍵路徑的發(fā)現(xiàn)。
(2)可根據(jù)自己興趣,給出一個(gè)具體的應(yīng)用情境,使得該題目成為一個(gè)實(shí)用軟件。(3)結(jié)點(diǎn)數(shù)目至少在30個(gè)以上。建圖數(shù)據(jù)從文件輸入,便于檢查。
5、Hash表應(yīng)用(必做)(查找)[問題描述] 設(shè)計(jì)散列表實(shí)現(xiàn)身份證查找系統(tǒng),對(duì)身份證號(hào)進(jìn)行Hash。[基本要求](1)設(shè)每個(gè)記錄有下列數(shù)據(jù)項(xiàng):身份證號(hào)碼(虛構(gòu),位數(shù)和編碼規(guī)則與真實(shí)一致即可)、姓名、地址。
(2)從文件輸入各記錄,以身份證號(hào)碼為關(guān)鍵字建立散列表。
(3)分別采用開放定址(自行選擇和設(shè)計(jì)定址方案)和鏈地址兩種方案解決沖突;顯示發(fā)生沖突的次數(shù)、每次中解決沖突進(jìn)行重定位的次數(shù)。(4)查找并顯示給定身份信息的記錄。(5)記錄條數(shù)至少在50條以上。
6、排序算法比較(必做)(排序)[問題描述] 利用隨機(jī)函數(shù)產(chǎn)生N個(gè)隨機(jī)整數(shù)(N = 500,1000,1500,2000,2500,…,30000),利用直接插入排序、折半插入排序,起泡排序、快速排序、選擇排序、堆排序,基數(shù)排序七種排序方法(可添加其它排序方法)進(jìn)行排序(結(jié)果為由小到大的順序),并統(tǒng)計(jì)每一種排序所耗費(fèi)的時(shí)間(即比較次數(shù)和交換次數(shù))。[基本要求](1)原始數(shù)據(jù)存在文件中,每個(gè)整數(shù)一行,方便讀入。(2)屏幕顯示每種排序所花的比較次數(shù)和交換次數(shù)。
(3)給出已有序的整數(shù)(正序和倒序)上述方法的變化情況,顯示在特例情況下的比較次數(shù)和交換次數(shù)。
7、迷宮問題
(選做)(棧與遞歸)[問題描述] 利用棧操作實(shí)現(xiàn)迷宮問題求解。[基本要求](1)隨機(jī)生成模擬迷宮地圖,不少于10行10列,存在文件中。(2)動(dòng)態(tài)顯示每一步的結(jié)果。(3)可在此基礎(chǔ)上有改進(jìn)方法。
8、家譜管理系統(tǒng)(選做)(樹)[問題描述] 實(shí)現(xiàn)具有下列功能的家譜管理系統(tǒng)。[基本要求](1)輸入文件以存放最初家譜中各成員的信息,成員的信息中均應(yīng)包含以下內(nèi)容:姓名、出生日期、婚否、地址、健在否、死亡日期(若其已死亡),也可附加其它信息、但不是必需的。
(2)實(shí)現(xiàn)數(shù)據(jù)的存盤和讀盤。(3)以圖形方式顯示家譜。
(4)顯示第n 代所有人的信息。
(5)按照姓名查詢,輸出成員信息(包括其本人、父親、孩子的信息)。(6)按照出生日期查詢成員名單。(7)輸入兩人姓名,確定其關(guān)系。(8)某成員添加孩子。
(9)刪除某成員(若其還有后代,則一并刪除)。(10)修改某成員信息。
(11)按出生日期對(duì)家譜中所有人排序。
(12)打開一家譜時(shí),提示當(dāng)天生日的健在成員。
(13)要求建立至少30個(gè)成員的數(shù)據(jù),以較為直觀的方式顯示結(jié)果,并提供文稿形式以便檢查。
(14)界面要求:有合理的提示,每個(gè)功能可以設(shè)立菜單,根據(jù)提示,可以完成相關(guān)的功能要求。
(15)存儲(chǔ)結(jié)構(gòu):根據(jù)系統(tǒng)功能要求自行設(shè)計(jì),但是要求相關(guān)數(shù)據(jù)要存儲(chǔ)在數(shù)據(jù)文件中。測(cè)試數(shù)據(jù):要求使用
1、全部合法數(shù)據(jù);
2、局部非法數(shù)據(jù)。進(jìn)行程序測(cè)試,以保證程序的穩(wěn)定。
9、旅游線路推薦問題(選做)(圖)[問題描述] 實(shí)現(xiàn)自駕游線路自動(dòng)推薦算法。選定目的地后,根據(jù)起始點(diǎn)和目的點(diǎn)之間的線路,除了最短路徑外,在圖上增加節(jié)點(diǎn)的權(quán)重值(根據(jù)節(jié)點(diǎn)的美景、美食、等屬性加權(quán)生成),生成融合最短路徑和最強(qiáng)旅游熱度的線路,并考慮成簡(jiǎn)單回路,盡量不走回頭路。[基本要求](1)以華東地區(qū)江蘇、上海、浙江、安徽的熱點(diǎn)景區(qū)為例。景點(diǎn)選擇至少20個(gè)以上,景點(diǎn)間的路徑長度可用百度地圖測(cè)量。(2)具體度量算法可自行設(shè)計(jì)。
(3)可以做成主題線路推薦,例如古民居游、海邊游、山村游等。(可選)
10、平衡二叉樹操作的演示(選做)(查找)[問題描述] 利用平衡二叉樹實(shí)現(xiàn)一個(gè)動(dòng)態(tài)查找表。[基本要求](1)實(shí)現(xiàn)動(dòng)態(tài)查找表的三種基本功能:查找、插入和刪除。(2)題目詳情見習(xí)題冊(cè)P168 6.4。
成績(jī)?cè)u(píng)定細(xì)則:
1.正確性:程序是否可以運(yùn)行,結(jié)果是否正確(20分)2.功能的完備性:是否實(shí)現(xiàn)要求的所有子功能(40分)
3.課程設(shè)計(jì)報(bào)告中的算法說明的清晰程度,課程設(shè)計(jì)報(bào)告中總結(jié)的深刻程度(20分)4.獨(dú)立完成情況(40分)總計(jì):100分
加分項(xiàng)目:
1.健壯性:異常處理的情況
2.可讀性:代碼編寫是否規(guī)范,是否便于閱讀。如函數(shù)、變量命名,‘{ }’的縮進(jìn),關(guān)鍵位臵適量注釋等
3.功能的完善:除要求實(shí)現(xiàn)的功能外,完成了其它的功能,實(shí)現(xiàn)了功能的完善 4.界面的設(shè)計(jì):可視化界面,或者交互良好的DOS界面
編程語言:C、C++ 或 JAVA 任選其一
檢查方式: 1.總體上檢查程序的代碼量,正確性,可讀性,健壯性,功能的完備性,代碼量,程序的結(jié)構(gòu)是否合理;局部檢查三個(gè)以上函數(shù)塊 2.檢查程序時(shí)同時(shí)檢查課程設(shè)計(jì)報(bào)告的電子文檔 3.檢查時(shí)間:每個(gè)學(xué)生的檢查時(shí)間10分鐘
時(shí)間安排: 上機(jī)地點(diǎn)、時(shí)間安排:
1號(hào)樓10層B、C區(qū)
18周周一(12.28)上午8:00 ~ 12:00 下午14:00~18:00 周二~五(12.29、12.30、12.31、1.1)下午14:00~18:00 周日(1.3)上午8:00 ~ 12:00 下午14:00~18:00 課程設(shè)計(jì)報(bào)告上交時(shí)間:1.3上機(jī)時(shí) 3 課程設(shè)計(jì)檢查時(shí)間:1.3上機(jī)時(shí)
課程設(shè)計(jì)報(bào)告要求:
1.所有的課程設(shè)計(jì)報(bào)告,均要有封面,包括:課題名稱、班級(jí)、學(xué)號(hào)、學(xué)生姓名、成績(jī)和指導(dǎo)教師;
2.給出自己采用的數(shù)據(jù)結(jié)構(gòu); 3.給出算法設(shè)計(jì)思想;
4.給出實(shí)現(xiàn)的源程序,并在必要的代碼處給出注釋; 5.給出測(cè)試數(shù)據(jù)和結(jié)果;
6.給出算法的時(shí)間復(fù)雜度、另外可以提出算法的改進(jìn)方法;
7.給出結(jié)束語:說明完成課程設(shè)計(jì)的情況,心得體會(huì);課程設(shè)計(jì)報(bào)告的電子文檔在上機(jī)檢查程序時(shí)一并檢查;書面文檔在指定的時(shí)間內(nèi)上交。
第二篇:2012數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
數(shù) 據(jù) 結(jié) 構(gòu)
課程設(shè)計(jì)報(bào)告
題 目: 一元多項(xiàng)式計(jì)算 專 業(yè): 信息管理與信息系統(tǒng) 班 級(jí): 2012級(jí)普本班 學(xué) 號(hào): 201201011367 姓 名: 左帥帥 指導(dǎo)老師: 郝慎學(xué) 時(shí) 間:
一、課程設(shè)計(jì)題目分析
本課程設(shè)計(jì)要求利用C語言或C++編寫,本程序?qū)崿F(xiàn)了一元多項(xiàng)式的加法、減法、乘法、除法運(yùn)算等功能。
二、設(shè)計(jì)思路
本程序采用C語言來完成課程設(shè)計(jì)。
1、首先,利用順序存儲(chǔ)結(jié)構(gòu)來構(gòu)造兩個(gè)存儲(chǔ)多項(xiàng)式A(x)和 B(x)的結(jié)構(gòu)。
2、然后把輸入,加,減,乘,除運(yùn)算分成五個(gè)主要的模塊:實(shí)現(xiàn)多項(xiàng)式輸入模塊、實(shí)現(xiàn)加法的模塊、實(shí)現(xiàn)減法的模塊、實(shí)現(xiàn)乘法的模塊、實(shí)現(xiàn)除法的模塊。
3、然后各個(gè)模塊里面還要分成若干種情況來考慮并通過函數(shù)的嵌套調(diào)用來實(shí)現(xiàn)其功能,盡量減少程序運(yùn)行時(shí)錯(cuò)誤的出現(xiàn)。
4、最后編寫main()主函數(shù)以實(shí)現(xiàn)對(duì)多項(xiàng)式輸入輸出以及加、減、乘、除,調(diào)試程序并將不足的地方加以修改。
三、設(shè)計(jì)算法分析
1、相關(guān)函數(shù)說明:
(1)定義數(shù)據(jù)結(jié)構(gòu)類型為線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)類型變量
typedef struct Polynomial{}
(2)其他功能函數(shù)
插入函數(shù)void Insert(Polyn p,Polyn h)
比較函數(shù)int compare(Polyn a,Polyn b)
建立一元多項(xiàng)式函數(shù)Polyn Create(Polyn head,int m)
求解并建立多項(xiàng)式a+b,Polyn Add(Polyn pa,Polyn pb)
求解并建立多項(xiàng)式a-b,Polyn Subtract(Polyn pa,Polyn pb)2
求解并建立多項(xiàng)式a*b,Polyn Multiply(Polyn pa,Polyn pb)
求解并建立多項(xiàng)式a/b,void Device(Polyn pa,Polyn pb)
輸出函數(shù)輸出多項(xiàng)式,void Print(Polyn P)
銷毀多項(xiàng)式函數(shù)釋放內(nèi)存,void Destroy(Polyn p)
主函數(shù),void main()
2、主程序的流程基函數(shù)調(diào)用說明(1)typedef struct Polynomial {
float coef;
int expn;
struct Polynomial *next;} *Polyn,Polynomial;
在這個(gè)結(jié)構(gòu)體變量中coef表示每一項(xiàng)前的系數(shù),expn表示每一項(xiàng)的指數(shù),polyn為結(jié)點(diǎn)指針類型,屬于抽象數(shù)據(jù)類型通常由用戶自行定義,Polynomial表示的是結(jié)構(gòu)體中的數(shù)據(jù)對(duì)象名。
(2)當(dāng)用戶輸入兩個(gè)一元多項(xiàng)式的系數(shù)和指數(shù)后,建立鏈表,存儲(chǔ)這兩個(gè)多項(xiàng)式,主要說明如下:
Polyn CreatePolyn(Polyn head,int m)建立一個(gè)頭指針為head、項(xiàng)數(shù)為m的一元多項(xiàng)式
p=head=(Polyn)malloc(sizeof(struct Polynomial));為輸入的多項(xiàng)式申請(qǐng)足夠的存儲(chǔ)空間
p=(Polyn)malloc(sizeof(struct Polynomial));建立新結(jié)點(diǎn)以接收數(shù)據(jù)
Insert(p,head);調(diào)用Insert函數(shù)插入結(jié)點(diǎn)
這就建立一元多項(xiàng)式的關(guān)鍵步驟
(3)由于多項(xiàng)式的系數(shù)和指數(shù)都是隨即輸入的,所以根據(jù)要求需要對(duì)多項(xiàng)式按指數(shù)進(jìn)行降冪排序。在這個(gè)程序模塊中,使用鏈表,根據(jù)對(duì)指數(shù)大小的比較,對(duì)各種情況進(jìn)行處理,此處由于反復(fù)使用指針對(duì)各個(gè)結(jié)點(diǎn)進(jìn)行定位,找到合適的位置再利用void Insert(Polyn p,Polyn h)進(jìn)行插入操作。(4)加、減、乘、除、的算法實(shí)現(xiàn):
在該程序中,最關(guān)鍵的一步是實(shí)現(xiàn)四則運(yùn)算和輸出,由于加減算法原則是一樣,減法可通過系數(shù)為負(fù)的加法實(shí)現(xiàn);對(duì)于乘除算法的大致流程都是:首先建立多項(xiàng)式a*b,a/b,然后使用鏈表存儲(chǔ)所求出的乘積,商和余數(shù)。這就實(shí)現(xiàn)了多項(xiàng)式計(jì)算模塊的主要功能。
(5)另一個(gè)子函數(shù)是輸出函數(shù) PrintPolyn();
輸出最終的結(jié)果,算法是將最后計(jì)算合并的鏈表逐個(gè)結(jié)點(diǎn)依次輸出,便得到整鏈表,也就是最后的計(jì)算式計(jì)算結(jié)果。由于考慮各個(gè)結(jié)點(diǎn)的指數(shù)情況不同,分別進(jìn)行了判斷處理。
四、程序新點(diǎn)
通過多次寫程序,發(fā)現(xiàn)在程序在控制臺(tái)運(yùn)行時(shí)總是黑色的,本次寫程序就想著改變一下,于是經(jīng)過查資料利用system(“Color E0”);可以函數(shù)解決,這里“E0,”E是控制臺(tái)背景顏色,0是控制臺(tái)輸出字體顏色。
五、設(shè)計(jì)中遇到的問題及解決辦法
首先是,由于此次課程設(shè)計(jì)里使用指針使用比較多,自己在指針多的時(shí)候易腦子混亂出錯(cuò),對(duì)于此問題我是采取比較笨的辦法在稿紙上寫明白后開始進(jìn)行 4
代碼編寫。
其次是,在寫除法模塊時(shí)比較復(fù)雜,自己通過查資料最后成功寫出除法模塊功能。
最后是,前期分析不足開始急于寫代碼,中途出現(xiàn)各種問題,算是給自己以后設(shè)計(jì)時(shí)的一個(gè)經(jīng)驗(yàn)吧。
六、測(cè)試(程序截圖)
1.數(shù)據(jù)輸入及主菜單
2.加法和減法模塊
3.乘法和除法模塊
七、總結(jié)
通過本次應(yīng)用C語言設(shè)計(jì)一元多項(xiàng)式基本計(jì)算程序,使我更加鞏固了C語言程序設(shè)計(jì)的知識(shí),以前對(duì)指針這一點(diǎn)使用是比較模糊,現(xiàn)在通過此次課程設(shè)計(jì)對(duì)指針理解的比較深刻了。而且對(duì)于數(shù)據(jù)結(jié)構(gòu)的相關(guān)算法和函數(shù)的調(diào)用方面知識(shí)的加深。本次的課程設(shè)計(jì),一方面提高了自己獨(dú)立思考處理問題的能力;另一方面使自己再設(shè)計(jì)開發(fā)程序方面有了一定的小經(jīng)驗(yàn)和想法,對(duì)自己以后學(xué)習(xí)其他語言程序設(shè)計(jì)奠定了一定的基礎(chǔ)。
八、指導(dǎo)老師評(píng)語及成績(jī)
附錄:(課程設(shè)計(jì)代碼)
#include
float coef;6
int expn;
struct Polynomial *next;} *Polyn,Polynomial;
//Polyn為結(jié)點(diǎn)指針類型 void Insert(Polyn p,Polyn h){
if(p->coef==0)free(p);
//系數(shù)為0的話釋放結(jié)點(diǎn)
else
{
Polyn q1,q2;
q1=h;q2=h->next;
while(q2&&p->expn
{
q1=q2;q2=q2->next;}
if(q2&&p->expn==q2->expn)//將指數(shù)相同相合并 {
q2->coef+=p->coef;
free(p);
if(!q2->coef)//系數(shù)為0的話釋放結(jié)點(diǎn)
{ q1->next=q2->next;free(q2);}
}
else { p->next=q2;q1->next=p;
}//指數(shù)為新時(shí)將結(jié)點(diǎn)插入
} 7
} //建立一個(gè)頭指針為head、項(xiàng)數(shù)為m的一元多項(xiàng)式 Polyn Create(Polyn head,int m){
int i;
Polyn p;
p=head=(Polyn)malloc(sizeof(struct Polynomial));
head->next=NULL;
for(i=0;i { p=(Polyn)malloc(sizeof(struct Polynomial));//建立新結(jié)點(diǎn)以接收數(shù)據(jù) printf(“請(qǐng)輸入第%d項(xiàng)的系數(shù)與指數(shù):”,i+1); scanf(“%f %d”,&p->coef,&p->expn); Insert(p,head); //調(diào)用Insert函數(shù)插入結(jié)點(diǎn) } return head;} //銷毀多項(xiàng)式p void Destroy(Polyn p){ Polyn q1,q2; q1=p->next;8 q2=q1->next; while(q1->next) { free(q1); q1=q2;//指針后移 q2=q2->next; } } //輸出多項(xiàng)式p int Print(Polyn P){ Polyn q=P->next; int flag=1;//項(xiàng)數(shù)計(jì)數(shù)器 if(!q)//若多項(xiàng)式為空,輸出0 { putchar('0'); printf(“n”); return; } while(q) { if(q->coef>0&&flag!=1)putchar('+');//系數(shù)大于0且不是第一項(xiàng) 9 if(q->coef!=1&&q->coef!=-1)//系數(shù)非1或-1的普通情況 { printf(“%g”,q->coef); if(q->expn==1)putchar('X'); else if(q->expn)printf(“X^%d”,q->expn); } else { if(q->coef==1){ if(!q->expn)putchar('1'); else if(q->expn==1)putchar('X'); else printf(“X^%d”,q->expn);} if(q->coef==-1){ if(!q->expn)printf(“-1”); else if(q->expn==1)printf(“-X”); else printf(“-X^%d”,q->expn);} } q=q->next; flag++; } printf(“n”);} int compare(Polyn a,Polyn b){ if(a&&b) { if(!b||a->expn>b->expn)return 1; else if(!a||a->expn else return 0; } else if(!a&&b)return-1;//a多項(xiàng)式已空,但b多項(xiàng)式非空 else return 1;//b多項(xiàng)式已空,但a多項(xiàng)式非空 } //求解并建立多項(xiàng)式a+b,返回其頭指針 Polyn Add(Polyn pa,Polyn pb){ Polyn qa=pa->next; Polyn qb=pb->next; Polyn headc,hc,qc; hc=(Polyn)malloc(sizeof(struct Polynomial));//建立頭結(jié)點(diǎn) 11 hc->next=NULL; headc=hc; while(qa||qb){ qc=(Polyn)malloc(sizeof(struct Polynomial)); switch(compare(qa,qb)) { case 1: qc->coef=qa->coef; qc->expn=qa->expn; qa=qa->next; break; case 0: qc->coef=qa->coef+qb->coef; qc->expn=qa->expn; qa=qa->next; qb=qb->next; break; case-1: qc->coef=qb->coef; qc->expn=qb->expn; qb=qb->next; break;12 } if(qc->coef!=0) { qc->next=hc->next; hc->next=qc; hc=qc; } else free(qc);//當(dāng)相加系數(shù)為0時(shí),釋放該結(jié)點(diǎn) } return headc;} //求解并建立多項(xiàng)式a-b,返回其頭指針 Polyn Subtract(Polyn pa,Polyn pb){ Polyn h=pb; Polyn p=pb->next; Polyn pd; while(p)//將pb的系數(shù)取反 { p->coef*=-1;p=p->next;} pd=Add(pa,h); for(p=h->next;p;p=p->next) //恢復(fù)pb的系數(shù) p->coef*=-1;13 return pd;} //求解并建立多項(xiàng)式a*b,返回其頭指針 Polyn Multiply(Polyn pa,Polyn pb){ Polyn hf,pf; Polyn qa=pa->next; Polyn qb=pb->next; hf=(Polyn)malloc(sizeof(struct Polynomial));//建立頭結(jié)點(diǎn) hf->next=NULL; for(;qa;qa=qa->next) { for(qb=pb->next;qb;qb=qb->next) { pf=(Polyn)malloc(sizeof(struct Polynomial)); pf->coef=qa->coef*qb->coef; pf->expn=qa->expn+qb->expn; Insert(pf,hf);//調(diào)用Insert函數(shù)以合并指數(shù)相同的項(xiàng) } } return hf;} //求解并建立多項(xiàng)式a/b,返回其頭指針 void Device(Polyn pa,Polyn pb){ Polyn hf,pf,temp1,temp2; Polyn qa=pa->next; Polyn qb=pb->next; hf=(Polyn)malloc(sizeof(struct Polynomial));//建立頭結(jié)點(diǎn),存儲(chǔ)商 hf->next=NULL; pf=(Polyn)malloc(sizeof(struct Polynomial));//建立頭結(jié)點(diǎn),存儲(chǔ)余數(shù) pf->next=NULL; temp1=(Polyn)malloc(sizeof(struct Polynomial)); temp1->next=NULL; temp2=(Polyn)malloc(sizeof(struct Polynomial)); temp2->next=NULL; temp1=Add(temp1,pa); while(qa!=NULL&&qa->expn>=qb->expn) { temp2->next=(Polyn)malloc(sizeof(struct Polynomial)); temp2->next->coef=(qa->coef)/(qb->coef); temp2->next->expn=(qa->expn)-(qb->expn); Insert(temp2->next,hf); pa=Subtract(pa,Multiply(pb,temp2));15 qa=pa->next; temp2->next=NULL; } pf=Subtract(temp1,Multiply(hf,pb)); pb=temp1; printf(“商是:”); Print(hf); printf(“余數(shù)是:”); Print(pf);} void main(){ int choose=1;int m,n,flag=0;system(“Color E0”);Polyn pa=0,pb=0,pc,pd,pf;//定義各式的頭指針,pa與pb在使用前付初值NULL printf(“請(qǐng)輸入A(x)的項(xiàng)數(shù):”);scanf(“%d”,&m);printf(“n”);pa=Create(pa,m);//建立多項(xiàng)式A printf(“n”);printf(“請(qǐng)輸入B(x)的項(xiàng)數(shù):”);16 scanf(“%d”,&n);printf(“n”);pb=Create(pb,n);//建立多項(xiàng)式B printf(“n”);printf(“**********************************************n”);printf(“* 多項(xiàng)式操作菜單 printf(”**********************************************n“);printf(”tt 1.輸出操作n“);printf(”tt 2.加法操作n“);printf(”tt 3.減法操作n“);printf(”tt 4.乘法操作n“);printf(”tt 5.除法操作n“);printf(”tt 6.退出操作n“);printf(”**********************************************n“);while(choose){ printf(”執(zhí)行操作:“); scanf(”%d“,&flag); switch(flag) { case 1: printf(”多項(xiàng)式A(x):“);Print(pa);*n”); printf(“多項(xiàng)式B(x):”);Print(pb); break; case 2: pc=Add(pa,pb); printf(“多項(xiàng)式A(x)+B(x):”);Print(pc); Destroy(pc);break; case 3: pd=Subtract(pa,pb); printf(“多項(xiàng)式A(x)-B(x):”);Print(pd); Destroy(pd);break; case 4: pf=Multiply(pa,pb); printf(“多項(xiàng)式A(x)*B(x):”); Print(pf); Destroy(pf); break; case 5: Device(pa,pb);18 break; case 6: exit(0); break; } } Destroy(pa); Destroy(pb);} 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì) 1.赫夫曼編碼器 設(shè)計(jì)一個(gè)利用赫夫曼算法的編碼和譯碼系統(tǒng),重復(fù)地顯示并處理以下項(xiàng)目,直到選擇退出為止。要求: 1)將權(quán)值數(shù)據(jù)存放在數(shù)據(jù)文件(文件名為data.txt,位于執(zhí)行程序的當(dāng)前目錄中) 2)初始化:鍵盤輸入字符集大小26、26個(gè)字符和26個(gè)權(quán)值(統(tǒng)計(jì)一篇英文文章中26個(gè)字母),建立哈夫曼樹; 3)編碼:利用建好的哈夫曼樹生成哈夫曼編碼; 4)輸出編碼(首先實(shí)現(xiàn)屏幕輸出,然后實(shí)現(xiàn)文件輸出); 5)界面優(yōu)化設(shè)計(jì)。 代碼如下: #include typedef struct HTNode //結(jié)構(gòu)體 { int Weight; char ch;int Parent,Lchild,Rchild;}HTNode;typedef char * * HCode; void Save(int n,HTNode *HT) //把權(quán)值保存到文件 { FILE * fp; int i; if((fp=fopen(“data.txt”,“wb”))==NULL) { printf(“cannot open filen”); return; } for(i=0;i if(fwrite(&HT[i].Weight,sizeof(struct HTNode),1,fp)!=1) printf(“file write errorn”); fclose(fp); system(“cls”); printf(“保存成功!”); } void Create_H(int n,int m,HTNode *HT) //建立赫夫曼樹,進(jìn)行編碼 { int w,k,j;char c;for(k=1;k<=m;k++){ if(k<=n) { printf(“n請(qǐng)輸入權(quán)值和字符(用空格隔開): ”); scanf(“%d”,&w); scanf(“ %c”,&c);HT[k].ch=c; HT[k].Weight=w; } else HT[k].Weight=0; HT[k].Parent=HT[k].Lchild=HT[k].Rchild=0;} int p1,p2,w1,w2; for(k=n+1;k<=m;k++){ p1=0;p2=0; w1=32767;w2=32767; for(j=1;j<=k-1;j++) { if(HT[j].Parent==0) { if(HT[j].Weight { w2=w1;p2=p1; w1=HT[j].Weight; p1=j; } else if(HT[j].Weight { w2=HT[j].Weight; p2=j; } } } HT[k].Lchild=p1;HT[k].Rchild=p2;HT[k].Weight=HT[p1].Weight+HT[p2].Weight; HT[p1].Parent=k;HT[p2].Parent=k; } printf(“輸入成功!”);} void Coding_H(int n,HTNode *HT) //對(duì)結(jié)點(diǎn)進(jìn)行譯碼 { int k,sp,fp,p;char *cd;HCode HC; HC=(HCode)malloc((n+1)*sizeof(char *)); cd=(char *)malloc(n*sizeof(char));cd[n-1]='
第三篇:數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)