版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p><b> 計算機科學(xué)與技術(shù)系</b></p><p><b> 課程設(shè)計報告</b></p><p> 2012~2013學(xué)年第二學(xué)期</p><p><b> 2013年 6月</b></p><p> 題目: 集合的并、交和差運算</p&g
2、t;<p><b> 【問題描述】</b></p><p> 編制一個能演示執(zhí)行集合的并、交和差運算的程序。</p><p><b> 【基本要求】</b></p><p> (1) 集合的元素限定為小寫字母字符 [‘a(chǎn)’..’z’] 。</p><p> (2) 演示程序以
3、用戶和計算機的對話方式執(zhí)行。</p><p><b> 【測試數(shù)據(jù)】</b></p><p> (1)Set1="magazine",Set2="paper",</p><p> Set1∪Set2="aegimnprz",Setl ∩Set2="ae",Se
4、t1-Set2="gimnz"。</p><p> (2)Set1= " 012oper4a6tion89",Set2="error data",</p><p> Set1∪Set2="adeinoprt",Setl ∩Set2="aeort",Set1-Set2="inp&
5、quot;。</p><p><b> 【實現(xiàn)提示】</b></p><p> 以有序鏈表表示集合。</p><p><b> 【選作內(nèi)容】</b></p><p> (1) 集合的元素判定和子集判定運算。</p><p> (2) 求集合的補集。</p>
6、;<p> (3) 集合的混合運算表達式求值。</p><p> (4) 集合的元素類型推廣到其他類型 , 甚至任意類型。</p><p><b> 實驗內(nèi)容</b></p><p> 實驗題目:編制一個演示集合的并、交和差運算的程序。</p><p><b> 需求分析:</b&
7、gt;</p><p> 1、 本演示程序中,集合的元素限定為小寫字母字符[“a”…”z”]。集合輸入的形式為一個以“回車符“為結(jié)束標(biāo)志的字符串,串中字符順序不限。</p><p> 2、 演示程序以用戶和計算機的對話方式執(zhí)行,即在計算機終端上顯示“提示信息“之后,由用戶在鍵盤上輸入演示程序中規(guī)定的運算命令;相應(yīng)的輸入數(shù)據(jù)和運算結(jié)果顯示在其后。</p>
8、;<p> 3、 程序執(zhí)行的命令包括:</p><p> 1) 構(gòu)造集合1;2)構(gòu)造在集合2;3)求并集;4)求交集;5)求差集;6)返回;7)結(jié)束。“構(gòu)造集合1”和“構(gòu)造集合2”時,需以字符的形式鍵入集合元素。</p><p><b> 二、數(shù)據(jù)結(jié)構(gòu)設(shè)計</b></p><p> 為了實現(xiàn)上述程序
9、的功能,應(yīng)以有序鏈表表示集合。為此,需要兩個抽象數(shù)據(jù)類型:有序表和集合。</p><p> 1、有序表的抽象數(shù)據(jù)類型定義為:</p><p> readdata(pointer head)</p><p> 初始條件:head是以head為頭節(jié)點的空鏈表。</p><p> 操作結(jié)果:生成以head為頭節(jié)點的非空鏈表。</p&g
10、t;<p> pop(pointer head)</p><p> 初始條件:head是以head為頭節(jié)點的非空鏈表。</p><p> 操作結(jié)果:將以head為頭節(jié)點的鏈表中數(shù)據(jù)逐個輸出。</p><p> 2、集合的抽象數(shù)據(jù)類型定義為:</p><p> and(pointer head1,pointer head
11、2,pointer head3)</p><p> 初始條件:鏈表head1、head2、head3已存在</p><p> 操作結(jié)果:生成一個由head1和head2的并集構(gòu)成的集合head3。</p><p> or(pointer head1,pointer head2,pointer head3)</p><p> 初始條件:
12、鏈表head1、head2、head3已存在</p><p> 操作結(jié)果:生成一個由head1和head2的交集構(gòu)成的集合head3。</p><p> differ(pointer head1,pointer head2,pointer head3)</p><p> 初始條件:鏈表head1、head2、head3已存在</p><p&
13、gt; 操作結(jié)果:生成一個由head1和head2的差集構(gòu)成的集合head3。</p><p> 3、本程序抱含四個模塊:</p><p> 1) 節(jié)點結(jié)構(gòu)單元模塊——定義有序表的節(jié)點結(jié)構(gòu);</p><p> 2) 有序表單元模塊——實現(xiàn)有序表的抽象數(shù)據(jù)類型;</p><p> 3) 集合單元模塊
14、——實現(xiàn)集合獲得抽象數(shù)據(jù)類型;</p><p><b> 4)主程序模塊:</b></p><p> Void main(){</p><p><b> 初始化;</b></p><p><b> do{</b></p><p><b>
15、; 接受命令;</b></p><p><b> 處理命令;</b></p><p> }while(“命令”!=“退出”);</p><p><b> }</b></p><p><b> 三、算法設(shè)計</b></p><p>
16、 #include<stdio.h></p><p> #include<stdlib.h></p><p> typedef struct LNode//定義結(jié)構(gòu)體類型指針</p><p><b> {</b></p><p> char data;</p><p&g
17、t; struct LNode*next;</p><p> }*pointer;</p><p> void readdata(pointer head)//定義輸入集合函數(shù)</p><p><b> {</b></p><p> pointer p;</p><p><b>
18、; char tmp;</b></p><p> scanf("%c",&tmp);</p><p> while(tmp!='\n')</p><p><b> {</b></p><p> p=(pointer)malloc(sizeof(struct
19、 LNode));</p><p> p->data=tmp;</p><p> p->next=head->next;</p><p> head->next=p;</p><p> scanf("%c",&tmp);</p><p><b>
20、}</b></p><p><b> }</b></p><p> void pop(pointer head)//定義輸出集合函數(shù)</p><p><b> {</b></p><p> pointer p;</p><p> p=head->n
21、ext;</p><p> while(p!=NULL)</p><p><b> {</b></p><p> printf("%c",p->data);</p><p> p=p->next;</p><p><b> }</b>
22、</p><p> printf("\n");</p><p><b> }</b></p><p> void and(pointer head1,pointer head2,pointer head3)//定義集合的并集函數(shù)</p><p><b> {</b><
23、;/p><p> pointer p1,p2,p3;</p><p> p1=head1->next;</p><p> while(p1!=NULL)</p><p><b> { </b></p><p> p3=(pointer)malloc(sizeof(struct LNo
24、de));</p><p> p3->data=p1->data;</p><p> p3->next=head3->next;</p><p> head3->next=p3;</p><p> p1=p1->next;</p><p><b> }</b
25、></p><p> p2=head2->next;</p><p> while(p2!=NULL)</p><p><b> {</b></p><p> p1=head1->next;</p><p> while((p1!=NULL)&&(p1-
26、>data!=p2->data))</p><p> p1=p1->next;</p><p> if (p1==NULL)</p><p><b> {</b></p><p> p3=(pointer)malloc(sizeof(struct LNode));</p><
27、p> p3->data=p2->data;</p><p> p3->next=head3->next;</p><p> head3->next=p3;</p><p><b> }</b></p><p> p2=p2->next;</p><p
28、><b> }</b></p><p><b> }</b></p><p> void or(pointer head1,pointer head2,pointer head3)//定義集合的交集函數(shù)</p><p><b> {</b></p><p> p
29、ointer p1,p2,p3;</p><p> p1=head1->next;</p><p> while(p1!=NULL)</p><p><b> {</b></p><p> p2=head2->next;</p><p> while((p2!=NULL)&a
30、mp;&(p2->data!=p1->data))</p><p> p2=p2->next;</p><p> if((p2!=NULL)&&(p2->data==p1->data))</p><p><b> {</b></p><p> p3=(poin
31、ter)malloc(sizeof(struct LNode));</p><p> p3->data=p1->data;</p><p> p3->next=head3->next;</p><p> head3->next=p3;</p><p><b> }</b></p
32、><p> p1=p1->next;</p><p><b> }</b></p><p><b> }</b></p><p> void differ(pointer head1,pointer head2,pointer head3)//定義集合的差集函數(shù)</p>&l
33、t;p><b> {</b></p><p> pointer p1,p2,p3;</p><p> p1=head1->next;</p><p> while(p1!=NULL)</p><p><b> {</b></p><p> p2=hea
34、d2->next;</p><p> while((p2!=NULL)&&(p2->data!=p1->data))</p><p> p2=p2->next;</p><p> if(p2==NULL)</p><p><b> {</b></p><
35、p> p3=(pointer)malloc(sizeof(struct LNode));</p><p> p3->data=p1->data;</p><p> p3->next=head3->next;</p><p> head3->next=p3;</p><p><b> }&
36、lt;/b></p><p> p1=p1->next;</p><p><b> }</b></p><p><b> }</b></p><p> void main()//主函數(shù)</p><p><b> {</b></
37、p><p><b> int x;</b></p><p> printf("(輸入數(shù)據(jù),按回車鍵結(jié)束,第一個集合大于第二個集合)\n");</p><p> pointer head1,head2,head3;</p><p> head1=(pointer)malloc(sizeof(stru
38、ct LNode));</p><p> head1->next=NULL;</p><p> head2=(pointer)malloc(sizeof(struct LNode));</p><p> head2->next=NULL;</p><p> head3=(pointer)malloc(sizeof(stru
39、ct LNode));</p><p> head3->next=NULL;</p><p> printf("請輸入集合1:\n");</p><p> readdata(head1);//調(diào)用輸入集合函數(shù)</p><p> printf("請輸入集合2:\n");</p>
40、<p> readdata(head2);//調(diào)用輸入集合函數(shù)</p><p> A:printf("1.并集 2.交集 3.差集 4.結(jié)束 x.重新運算\n");</p><p><b> do{</b></p><p> printf("請選擇序號\n");</p&g
41、t;<p> scanf("%d",&x);</p><p><b> switch(x)</b></p><p><b> {</b></p><p><b> case 1:</b></p><p> printf(&qu
42、ot;兩集合的并是\n");</p><p> and(head1,head2,head3);//調(diào)用并集函數(shù)</p><p> pop(head3);</p><p> head3->next=NULL;</p><p><b> break;</b></p><p>&
43、lt;b> case 2:</b></p><p> printf("兩集合的交是\n");</p><p> or(head1,head2,head3);//調(diào)用交集函數(shù)</p><p> pop(head3);</p><p> head3->next=NULL;</p>
44、<p><b> break;</b></p><p><b> case 3:</b></p><p> printf("兩集合的差是\n");</p><p> differ(head1,head2,head3);//調(diào)用差集函數(shù)</p><p> po
45、p(head3);</p><p> head3->next=NULL;</p><p><b> break; </b></p><p> case 4:break;</p><p> default:goto A;</p><p><b> }</b>&l
46、t;/p><p> }while(x!=4);</p><p><b> }</b></p><p> 四、測試數(shù)據(jù)及程序運行情況 </p><p><b> 運行時提示輸入:</b></p><p><b> 輸入集合1:asd</b></
47、p><p><b> 輸入集合2:asf</b></p><p> 根據(jù)提示輸入運算類型:1.并集 2.交集 3.差集 4.結(jié)束 x.重新運算 </p><p> 輸入1,輸出”fasd”</p><p> 輸入2,輸出”as”</p><p><b> 輸入3,輸出”d
48、”</b></p><p> 輸入4,輸出”press any key to continue”(結(jié)束)</p><p> 輸入其他數(shù),輸出” 1.并集 2.交集 3.差集 4.結(jié)束 x.重新運算”(重新選擇運算類型)</p><p> 下面是運行時的界面(附圖):</p><p><b> 五、參考資料
49、</b></p><p> [1] 王昆侖,李紅. 數(shù)據(jù)結(jié)構(gòu)與算法. 北京:中國鐵道出版社,2006年5月。</p><p> [2] 陳朔鷹,《C語言程序設(shè)計習(xí)題集(第二版)》,人民郵電出版社,2003.2</p><p> [3] 嚴(yán)蔚敏 吳偉民. 《數(shù)據(jù)結(jié)構(gòu)(C語言版) 》. 北京: 清華大學(xué)出版社,2009</p><p
溫馨提示
- 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)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-- 集合的并、交和差運算
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--集合的并、交和差運算
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--編制一個演示集合的并、交和差運算的程序
- 數(shù)據(jù)庫課程設(shè)計---集合交、并、差、對稱差運算
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告(集合交集并集運算)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計集合的交并差運算
- java語言課程設(shè)計--集合的并、交和差運算
- 數(shù)據(jù)結(jié)構(gòu)----集合運算課程設(shè)計報告(c++)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--文章編輯集合運算
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告-長整數(shù)運算
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告---二叉排序樹實現(xiàn)集合的運算
- 西安石油大學(xué)數(shù)據(jù)結(jié)構(gòu)數(shù)據(jù)結(jié)構(gòu)程序設(shè)計報告--設(shè)計一個一元稀疏多項式簡單計算器和集合的并,交和差運算
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-- 稀疏矩陣的運算
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--大整數(shù)的運算
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計報告--稀疏矩陣運算器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告--稀疏矩陣運算器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告 稀疏矩陣運算器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告 稀疏矩陣運算器設(shè)計
評論
0/150
提交評論