《數據結構》課程設計報告運動會分數統(tǒng)計 一元多項式 迷宮求解 文章編輯 紙牌游戲等

上傳人:仙*** 文檔編號:28472000 上傳時間:2021-08-28 格式:DOC 頁數:35 大小:431.50KB
收藏 版權申訴 舉報 下載
《數據結構》課程設計報告運動會分數統(tǒng)計 一元多項式 迷宮求解 文章編輯 紙牌游戲等_第1頁
第1頁 / 共35頁
《數據結構》課程設計報告運動會分數統(tǒng)計 一元多項式 迷宮求解 文章編輯 紙牌游戲等_第2頁
第2頁 / 共35頁
《數據結構》課程設計報告運動會分數統(tǒng)計 一元多項式 迷宮求解 文章編輯 紙牌游戲等_第3頁
第3頁 / 共35頁

下載文檔到電腦,查找使用更方便

15 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《《數據結構》課程設計報告運動會分數統(tǒng)計 一元多項式 迷宮求解 文章編輯 紙牌游戲等》由會員分享,可在線閱讀,更多相關《《數據結構》課程設計報告運動會分數統(tǒng)計 一元多項式 迷宮求解 文章編輯 紙牌游戲等(35頁珍藏版)》請在裝配圖網上搜索。

1、《數據結構》課程設計報告 南京林業(yè)大學 數據結構課程設計報告 專業(yè): 計算機科學與技術 課程名稱: 數據結構 姓名: 學號: 090801126 指導老師: 時間: 2011年1月 目錄要點: 一. 具體內容(題目) ……………………………………1 二. 需求分析(功能要求) ………………………………2 三. 概要設計(程序設計思想) …………………………3 四.

2、 詳細設計(源代碼) ……………………………………6 五. 調試分析(運行結果顯示及說明) ………………31 六. 課設總結 ………………………………………………34 具體內容: 題目1: 運動會分數統(tǒng)計** 任務:參加運動會有n個學校,學校編號為1……n。比賽分成m個男子項目,和w個女子項目。項目編號為男子1……m,女子m+1……m+w。不同的項目取前五名或前三名積分;取前五名的積分分別為:7,5,3,2,1,取前三名的積分分別為:5,3,2,;哪些取前五名或前三名由學生自己設定。(m〈=20,n〈=20); 題目2:一元多項式** 任務:能夠按照指數降序

3、排列建立并輸出多項式; 能夠完成兩個多項式的相加,相減,并將結果輸入; 題目4:迷宮求解 任務:可以輸入一個任意大小的迷宮數據,用非遞歸的方法求出一條走出迷宮的路徑,并將路徑輸出; 題目5:文章編輯** 功能:輸入一頁文字,程序可以統(tǒng)計出文字、數字、空格的個數。 靜態(tài)存儲一頁文章,每行最多不超過80個字符,共N行; 題目6:Joseph環(huán) 任務:編號是1,2,……,n的n個人按照順時針方向圍坐一圈,每個人只有一個密碼(正整數)。一開始任選一個正整數作為報數上限值m,從第一個仍開始順時針方向自1開始順序報數,報到m時停止報數。報m的人出列,將他的密碼作為新的m值,從他在順時針方

4、向的下一個人開始重新從1報數,如此下去,直到所有的人出列為止。設計一個程序來求出出列的順序。 題目7:猴子選大王** 任務:一堆猴子都有編號,編號是1,2,3 ...m ,這群猴子(m個)按照1-m的順序圍坐一圈,從第1開始數,每數到第N個,該猴子就要離開此圈,這樣依次下來,直到圈中只剩下最后一只猴子,則該猴子為大王?! ? 題目8:建立二叉樹,層序、先序遍歷( 用遞歸或非遞歸的方法都可以) ** 任務:要求能夠輸入樹的各個結點,并能夠輸出用不同方法遍歷的遍歷序列; 題目9:紙牌游戲** 任務:編號為1-52張牌,正面向上,從第2張開始,以2為基數,是2的倍數的牌翻一次,直到最后

5、一張牌;然后,從第3張開始,以3為基數,是3的倍數的牌翻一次,直到最后一張牌;然后…從第4張開始,以4為基數,是4的倍數的牌翻一次, 直到最后一張牌;...再依次5的倍數的牌翻一次,6的,7的 直到 以52為基數的 翻過,輸出:這時正面向上的牌有哪些? 需求分析: 運動會分數統(tǒng)計 1)可以輸入前三名或前五名的成績; 2)能統(tǒng)計各學??偡?; 3)可以按學校編號,學??偡?,男女團體總分排序輸出; 4) 可以按學校編號查詢學校某個項目的情況;可以按項目編號查詢查詢取得前三名或前五名的學校。 規(guī)定:輸入數據形式和范圍:20以內的整數 輸出形式:有中文提示,各學校分數為整形 界面要

6、求:有合理的提示,每個功能可以設立菜單,根據提示,可以完成相關的功能要求; 一元多項式計算 能夠完成兩個多項式的相加,相減,并將結果輸入; 迷宮求解 要求:在上交資料中請寫明:存儲結構、基本算法(可以使用程序流程圖)、源程序、測試數據和結果、算法的時間復雜度、另外可以提出算法的改進方法; 文章編輯 (1)分別統(tǒng)計出其中英文字母數和空格數及整篇文章總字數; (2)統(tǒng)計某一字符串在文章中出現的次數并輸出該次數,用函數letter_num(),figure_num(),space_num(),total_num()來實現。 (3)刪除某一子串,并將后面的字符前移,用delstr()來

7、實現。 存儲結構使用線性表,分別用幾個子函數實現相應的功能; 輸入數據的形式和范圍:可以輸入大寫、小寫的英文字母、任何數字及標點符號。 輸出形式:(1)分行輸出用戶輸入的各行字符; (2)分4行輸出"全部字母數"、"數字個數"、"空格個數"、"文章總字數" (3)輸出刪除某一字符串后的文章; Joseph環(huán) 利用單向循環(huán)鏈表存儲結構模擬此過程,按照出列的順序輸出各個人的編號。 輸入數據:建立輸入處理數據,輸入m的初值,n,輸入每個人的密碼,建立單循環(huán)鏈表。 輸出是什么:建立一個輸出函數,將正確的輸出序列; 猴子選大王  輸入數據:輸入m,n m,n 為整數,n

8、出形式:中文提示按照m個猴子,數n 個數的方法,輸出為大王的猴子是幾號 ,建立一個函數來實現此功能;首先用一個數組來存放猴子的編號,從1到m,然后用hzxdw()按題目要求,用兩個雙重循環(huán)來實現猴子大王的選舉. 建立二叉樹 typedef struct node 是定義二叉樹的存儲結構 creat(bitree *bt)是用來建立二叉樹的輸入的 levelorder(bitnode *bt,int m)是用來建立層序遍歷序列的 preorder(bitree bt)是用來實現非遞歸先序遍歷的 main是主函數 紙牌游戲 直接用函數main()按照題目要求的規(guī)則, 只使用數組和用

9、幾個循環(huán)來實現. 概要設計: 運動會分數統(tǒng)計: 先分配存儲的空間;輸入運動項目個數、參加的學校的個數、男子比賽項目的個數、女子比賽項目的個數;循環(huán)每個項目的輸入;自行選擇取前三名還是前五名,循環(huán)輸入姓名、成績、學校;通過調用子函數進行計算;輸出結果。 一元多項式計算: 通過typedef struct polynode來定義單鏈表存儲多項式的結點結構。 利用尾插法建立一元多項式的鏈表,先建立多項式的頭結點,當表不為空的時候,申請新的結點,并分配存儲空間,在當前的尾表做插入,最后將表的最后一個結點的next置NULL,以表示結束。 兩個多項式的相加:當兩個多項式均未掃描結束時若

10、指數不等則到下一個結點,若指數相等且不為零時,相應的系數相加,若系數都為零時,則刪除接點p與q,并將指針指向下一個結點,否則將q結點加入到和多項式中。若多項式A中還有剩余,則將剩余的結點加入到和多項式中否則,將B中的結點加入到和多項式中。兩個多項式的相減與相加類似; 總流程圖: 文章編輯: 用串來存放一篇文章,文章錄入以#作為結束,然后統(tǒng)計文章各種數據,直到#號為止,查找用戶要統(tǒng)計的和刪除的字符都是一樣的思想,刪除某一子串,并將后面的字符前移。 Joseph環(huán): 建立單循環(huán)鏈表,依次根據提示輸入m,n,及code值。 猴子選大王:

11、 猴子的存放采用鏈式存儲結構,利用循環(huán)鏈表來實現建立的,其表示方法是遞歸定義的: typedef struct Mnode { int data; struct Mnode *next; }Mnode; 根據題目要求,要讓這M只猴子順序圍坐一圈,那就得用循環(huán)鏈表king(Linklist L,int n) 在主函數中,根據提示先輸入猴子的總的數量m,再輸入數的數n,最后調用子函數進行選擇,輸出猴子王的編號。 建立二叉樹: 在typedef struct node中定義二叉樹bitree的左右結點分別為l

12、child、rchild。 在輸入函數中,把輸入‘.’代表空;若輸入不為空,則分配存儲空間,并使其產生左右結點。 在層序遍歷函數中,先定義一個數組,然后遍歷他的左孩子結點,若不為空就放到數組中,再遍歷右孩子結點,若不為空也放到數組中。二叉樹的層序遍歷是由上至下一層一層地遍歷的。 主函數中,先提示輸入一個樹調用二叉樹輸入函數,然后調用層序遍歷函數,再調用遞歸先序遍歷函數。 紙牌游戲: 通過循環(huán)和連續(xù)乘-1進行翻牌,把值為1的定義為朝上的牌。 先定義52個牌;把每個牌都賦值為1;通過循環(huán)(52張牌的循環(huán)和基數的循環(huán)),并判斷基數,每翻一次牌都乘-1,最后為1的數就是朝上的牌。

13、 時間復雜度為o[1]; 程序實現思想: 首先必須確定實現這個課程設計的主算法是使用鏈式存儲結構還是棧又或是數組和廣義表。 根據題目要求需要實現的功能有: 1、 數據錄入:輸入各種數據; 此處即創(chuàng)建鏈表的過程,調用一個成員函數負值。在此處還有一個方法實現,即先輸入數據,然后再調用構造實現。 2、數據統(tǒng)計: 存儲方式的選擇,是使用鏈式存儲結構還是棧又或是數組和廣義表;遵守先定義后調用的原則;數組定義時注意下標的起始值和上限;鏈表定義時注意結點中的項;準確運用結點。 3、 數據輸出:按要求的格式打印 調用do循環(huán)和for循環(huán),通過遍歷鏈表實現輸出,用printf語句輸

14、出。 4、 查找,修改,刪除: 這三個功能的核心是尋找成員,先遍歷鏈表,然后尋找對應的ID號來找到結點,然后再對結點實行刪除,修改操作。 詳細設計(源程序): 1.運動會分數統(tǒng)計: #include #include #include #include #include #define MAX 50 #define NULL 0 typedef struct node1{ int school;

15、 /*學校編號*/ int record; /*項目成績*/ struct node1 *next; }Schools; typedef struct { int item; /*項目編號*/ Schools *firstschool; }ITEM; typedef struct {

16、int z; /* 項目總數 */ ITEM a[MAX]; }ALLitems; typedef struct node2 { int item; /*該學校獲獎的項目*/ int record; /*項目成績*/ struct node2 *next; }Items; typedef struc

17、t { int school; /*學校編號*/ int score; /*學??偡?/ int boys; /*男團體總分*/ int girls; /*女團體總分*/ Items *firstitem; }SCHNode; typedef struct {

18、 int n; /* 學??倲?*/ SCHNode b[MAX]; }ALLNode; ALLitems *g1; ALLNode *g2; void funct1(ALLitems *g1,ALLNode *g2) /* 輸入各個項目成績 */ { Schools *p1; Items *p2; int i,j,k,m,w,h,x; printf("\n*** enter the informa

19、tion of every item ***\n\n"); printf("enter the total number of male-items m:"); scanf("%d",&m); if(m<0||m>20) { printf("enter error,m<=20,please enter again:"); scanf("%d",&m); } printf("enter the total number of female-items w:"); scanf("%d",&w

20、); if(w<0||w>20) { printf("enter error,w<=20,please enter again:"); scanf("%d",&w); } printf("enter the total number of schools n:"); scanf("%d",&g2->n); if(g2->n<0||g2->n>20) { printf("entr error,n<=20,please enter again:"); scanf("%d

21、",&g2->n); } g1->z=m+w; printf("item number for boys 1-%d,girls %d-%d",m,m+1,g1->z); printf("\n\n*** record ***\n(0 stands for ending)"); for(k=1;k<=g1->z;k++) /* 對兩個鄰接表置初態(tài) */ { g1->a[k].item=k; g1->a[k].firstschool=NULL; }

22、 for(k=1;k<=g2->n;k++) { g2->b[k].school=k; g2->b[k].firstitem=NULL; g2->b[k].score=g2->b[k].boys=g2->b[k].girls=NULL; } g2->b[0].score=g2->b[0].boys=g2->b[0].girls=NULL; while(i!=0) { printf("\nitem:"); scanf("%d",&i); if(i

23、!=0) { printf("1.the three or 2.the five \n"); printf("please choose 1 or 2:"); scanf("%d",&j); if(j!=1&&j!=2) { printf("enter error,please enter again:"); scanf("%d",&j); } if(j==1)

24、/* 該項目只有前三名時執(zhí)行此語句 */ { h=3; do{ printf("arrange %d:school(school is number)",h); scanf("%d",&x); p1=(Schools *)malloc(sizeof(Schools)); p1->school=x; p2=(Items *)malloc(sizeof(Items)); p2->i

25、tem=i; if(h==3) p2->record=p1->record=2; if(h==2) p2->record=p1->record=3; if(h==1) p2->record=p1->record=5; p1->next=g1->a[i].firstschool; g1->a[i].firstschool=p1; p2->next=g2->b[x].firstitem;

26、 g2->b[x].firstitem=p2; g2->b[x].score=g2->b[x].score+p2->record; /* 累計總分 */ if(i<=m) g2->b[x].boys=g2->b[x].boys+p2->record; /* 累計男團體總分 */ else g2->b[x].girls=g2->b[x].girls+p2->record; /* 累計女團體總分 */ h--; }while

27、(x!=0&&h!=0); } if(j==2) /* 該項目有前五名時執(zhí)行此語句 */ { h=5; do{ printf("arrange %d:school(school is number)",h); scanf("%d",&x); p1=(Schools *)malloc(sizeof(Schools)); p1->school=x;

28、 p2=(Items *)malloc(sizeof(Items)); p2->item=i; if(h==5) p2->record=p1->record=1; if(h==4) p2->record=p1->record=2; if(h==3) p2->record=p1->record=3; if(h==2) p2->record=p1->record=5; if(

29、h==1) p2->record=p1->record=7; p1->next=g1->a[i].firstschool; g1->a[i].firstschool=p1; p2->next=g2->b[x].firstitem; g2->b[x].firstitem=p2; g2->b[x].score=g2->b[x].score+p2->record; /* 累計總分 */ if(i<=m) g2-

30、>b[x].boys=g2->b[x].boys+p2->record; /* 累計男團體總分 */ else g2->b[x].girls=g2->b[x].girls+p2->record; /* 累計女團體總分 */ h--; }while(x!=0&&h!=0); } } } } void save() /* 存儲數據文件 */ { FILE *fp1,*fp2; if((fp1=

31、fopen("sports1","wb"))==NULL) { printf("cannot open file.\n"); return; } if(fwrite(g1,sizeof(ALLitems),1,fp1)!=1) printf("file write error.\n"); fclose(fp1); if((fp2=fopen("sports2","wb"))==NULL) { printf("cannot open file.\n"); return;

32、 } if(fwrite(g2,sizeof(ALLNode),1,fp2)!=1) printf("file write error.\n"); fclose(fp2); } void funct2(ALLNode *g2) /* 輸出各學??偡?*/ { int k; printf("\n\n*** output the score ***\n"); printf("school\t score \n"); for(k

33、=1;k<=g2->n;k++) printf("%d\t\t %d\n",k,g2->b[k].score); printf("\n"); printf("press any butter to the main menu......"); getch(); } void funct3(ALLNode *g2) /* 按學校編號排序輸出 */ { int k; Items *p2; printf("\n\n*** arranging output by sch

34、ool ***\n"); printf("school\t\t\t the grade of item \n"); for(k=1;k<=g2->n;k++) { printf("%d\t",k); p2=g2->b[k].firstitem; while(p2!=NULL) { printf("item %d:get the grade of %d ",p2->item,p2->record); p2=p2->next; } printf("\n");

35、 } printf("\n"); printf("press any butter to the main menu......"); getch(); } void funct4(ALLNode *g2) /* 按學??偡峙判蜉敵?*/ { int i,j,k; printf("\n\n*** arranging output by the score ***\n"); printf("school\t score \n"); for(i=

36、2;i<=g2->n;i++) { g2->b[0].score=g2->b[i].score; g2->b[0].boys=g2->b[i].boys; g2->b[0].girls=g2->b[i].girls; g2->b[0].school=g2->b[i].school; j=i-1; while(g2->b[0].scoreb[j].score&&j>0) { g2->b[j+1].score=g2->b[j].score; g2->b[j+1]

37、.boys=g2->b[j].boys; g2->b[j+1].girls=g2->b[j].girls; g2->b[j+1].school=g2->b[j].school; j--; } g2->b[j+1].score=g2->b[0].score; g2->b[j+1].boys=g2->b[0].boys; g2->b[j+1].girls=g2->b[0].girls; g2->b[j+1].school=g2->b[0].school;

38、 } for(k=1;k<=g2->n;k++) printf("%d \t\t%d\n",g2->b[k].school,g2->b[k].score); printf("press any butter to the main menu......"); getch(); } void funct5(ALLNode *g2) /* 按男團體總分排序輸出 */ { int i,j,k; printf("\n*** arranging output by boy

39、s ***\n"); printf("school\t boys \n"); for(i=2;i<=g2->n;i++) { g2->b[0].score=g2->b[i].score; g2->b[0].boys=g2->b[i].boys; g2->b[0].girls=g2->b[i].girls; g2->b[0].school=g2->b[i].school; j=i-1; while(g2->b[0].boysb[j].boys&&j>0)

40、 { g2->b[j+1].score=g2->b[j].score; g2->b[j+1].boys=g2->b[j].boys; g2->b[j+1].girls=g2->b[j].girls; g2->b[j+1].school=g2->b[j].school; j--; } g2->b[j+1].score=g2->b[0].score; g2->b[j+1].boys=g2->b[0].boys; g2->b[j+1].girls=g2-

41、>b[0].girls; g2->b[j+1].school=g2->b[0].school; } for(k=1;k<=g2->n;k++) printf("%d\t\t %d\n",g2->b[k].school,g2->b[k].boys); printf("press any butter to the main menu......"); getch(); } void funct6(ALLNode *g2) /* 按女團體總分排序輸出 */

42、 { int i,j,k; printf("\n*** arranging output by girls ***\n"); printf("school\t girls \n"); for(i=2;i<=g2->n;i++) { g2->b[0].score=g2->b[i].score; g2->b[0].boys=g2->b[i].boys; g2->b[0].girls=g2->b[i].girls; g2->b[0].school=g2->b[i].school; j

43、=i-1; while(g2->b[0].girlsb[j].girls&&j>0) { g2->b[j+1].score=g2->b[j].score; g2->b[j+1].boys=g2->b[j].boys; g2->b[j+1].girls=g2->b[j].girls; g2->b[j+1].school=g2->b[j].school; j--; } g2->b[j+1].score=g2->b[0].score;

44、 g2->b[j+1].boys=g2->b[0].boys; g2->b[j+1].girls=g2->b[0].girls; g2->b[j+1].school=g2->b[0].school; } for(k=1;k<=g2->n;k++) printf("%d\t\t %d\n",g2->b[k].school,g2->b[k].girls); printf("press any butter to the main menu......"); getch(); } vo

45、id funct7(ALLNode *g2) /* 按學校編號查詢學校某個項目情況 */ { int i,j,k; Items *p2; printf("\n *** look for the grade of a item by school ***\n"); printf("enter the school you are looking for:"); scanf("%d",&i); printf("enter the item you are looking for:"); sc

46、anf("%d",&j); p2=g2->b[i].firstitem; while(p2!=NULL) { if(p2->item==j) printf("school:%d\t item:%d\t record:%d\n",i,p2->item,p2->record); p2=p2->next; } printf("\n"); printf("press any butter to the main menu......"); getch(); }

47、 void funct8(ALLitems *g1) /* 按項目編號查詢取得名次的學校 */ { int i,k; Schools *p1; printf("\n*** look for the win-school by item ***\n"); printf("enter the item you are looking for:"); scanf("%d",&i); printf("item \t\t\tthe win-school\n"); printf("%d\

48、t",i); p1=g1->a[i].firstschool; while(p1!=NULL) { printf(" school %d:get the grade of %d ",p1->school,p1->record); p1=p1->next; } printf("\n\n"); printf("press any butter to the main menu......"); getch(); } void main() { int t;

49、 ALLitems *g1; ALLNode *g2; for(;;) { printf("\t\t the score of the sports \n"); /* 運動會分數統(tǒng)計*/ printf("\t\t* * * * * * * * * * * * * * * * * * * * * * * * * * * * * \n"); printf("\t\t \n");

50、 printf("\t\t* * * * * * * * * * * * * * * * * * * * * * * * * * * * * \n"); printf("\t\t* 1.entering each record and save it *\n"); /* .輸入各個項目成績并存儲文件 */ printf("\t\t* 2.accumulating the score of each school *\n"); /* 統(tǒng)計各學??偡?/ printf("\t\t*

51、 3.arranging output by the school *\n"); /* 按學校編號排序輸出*/ printf("\t\t* 4.arranging output by the score *\n"); /* 按學??偡峙判蜉敵?/ printf("\t\t* 5.arranging output by boys *\n"); /* 按男團體總分排序輸出*/ printf("\t\t*

52、 6.arranging output by girls *\n"); /* 按女團體總分排序輸出*/ printf("\t\t* 7.looking for the score of a item by school *\n"); /* 按學校編號查詢學校某個項目情況*/ printf("\t\t* 8.looking for the win-school by item *\n"); /* 按項目編號查詢取得名次的學校*/ printf("\t\t*

53、 0.exit *\n"); printf("\t\t* * * * * * * * * * * * * * * * * * * * * * * * * * * * * \n"); printf("\t\t please choose (0-8):"); loop:scanf("%d",&t); switch(t) { case 1:funct1(g1,g2);save();break; ca

54、se 2:funct2(g2);break; case 3:funct3(g2);break; case 4:funct4(g2);break; case 5:funct5(g2);break; case 6:funct6(g2);break; case 7:funct7(g2);break; case 8:funct8(g1);break; case 0:exit(0); default:{ printf("enter error,p

55、lease enter again:"); goto loop;} } } } 2.一元多項式計算 #include #include #include #define LEN sizeof(struct poly) struct poly { int coef; int index

56、; struct poly * next; }; void print_poly(struct poly *head) { struct poly *p1; printf("%d次%d項式:",head->index,head->coef); p1=head->next; while(p1!=NULL) { if(p1->coef>0) { if(p1->index!=1&&p1->index!=0) printf("%dx^%d+",p1->coef,p1->index); else if(p1->index==1) pri

57、ntf("%dx+",p1->coef); else printf("%d+",p1->coef); } else if(p1->coef<0) { if(p1->index!=1&&p1->index!=0) printf("(%d)x^%d+",p1->coef,p1->index); else if(p1->index==1) printf("(%d)x+",p1->coef); else printf("(%d)+",p1->coef); } p1=p1->next; } print

58、f("\b \n"); } struct poly * creat_poly() { struct poly *p1,*p2,*head; head=(struct poly *)malloc(LEN); head->coef=head->index=0; head->next=NULL; printf("請輸入要創(chuàng)建的多項式(如A(x)=5x^17+9x^8+3x+7,請輸入\"5^17 9^8 3^1 7^0 0^0\":\n"); p1=(struct poly *)malloc(LEN); scanf("%d^%d",&p1->coef,&p1

59、->index); while(p1->coef!=0) { p2=head; while(p2->next!=NULL) { if(p2->next->indexindex) break; p2=p2->next; } p1->next=p2->next; p2->next=p1; (head->coef)++; if(p1->index>head->index) head->index=p1->index; p1=(struct poly *)malloc(LEN);

60、 scanf("%d^%d",&p1->coef,&p1->index); } p1->next=NULL; return(head); } struct poly * add_poly(struct poly *head1,struct poly *head2) { struct poly *p1,*p2,*head3,*p3; p1=head1->next; p2=head2->next; head3=(struct poly *)malloc(LEN); p3=head3; head3->coef=head3->index=0

61、; head3->next=NULL; while(p1!=NULL&&p2!=NULL) { if(p1->index>p2->index) { p3->next=p1; (head3->coef)++; p1=p1->next; p3=p3->next; } else if(p1->index==p2->index) { if(p1->coef+p2->coef!=0) { p3->next=(struct poly *)malloc(LEN); (p

62、3->next)->coef=p1->coef+p2->coef; (p3->next)->index=p1->index; (head3->coef)++; p3=p3->next; } p1=p1->next; p2=p2->next; } else if(p1->indexindex) { p3->next=p2; (head3->coef)++; p2=p2->next;

63、 p3=p3->next; } } if(p1==NULL) p3->next=p2; else if(p2==NULL) p3->next=p1; p3=p3->next; while(p3!=NULL) { (head3->coef)++; p3=p3->next; } if(head3->next!=NULL) head3->index=head3->next->index; return(head3); } struct poly * sub_poly(struct poly *head1,str

64、uct poly *head2) { struct poly *p1,*head3; p1=head2->next; while(p1!=NULL) { p1->coef=0-p1->coef; p1=p1->next; } head3=add_poly(head1,head2); return(head3); } int main() { struct poly *head1,*head2,*head3; char flag; printf("正在創(chuàng)建多項式一:\n"); head1=creat_poly

65、(); printf("您創(chuàng)建的多項式為:\n\t"); print_poly(head1); printf("\n正在創(chuàng)建多項式二:\n"); head2=creat_poly(); printf("您創(chuàng)建的多項式為:\n\t"); print_poly(head2); do{ printf("\n請選擇運算符號(+或-):"); getchar(); flag=getchar(); if(flag!=+&&flag!=-) printf("\n輸入錯誤!請重新輸入!\n"); }while(fla

66、g!=+&&flag!=-); switch(flag) { case +:head3=add_poly(head1,head2);break; case -:head3=sub_poly(head1,head2);break; } printf("\n計算的結果是:\n"); print_poly(head3); printf("\n按[Enter]結束。"); getchar(); getchar(); } 4.迷宮求解 #include #include #define M 10 /* 10*10 */ #define OK 1 #define ERROR 0 #define OVERFLOW -1 #define STACK_INIT_SIZE 100 #define

展開閱讀全文
溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
5. 裝配圖網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

相關資源

更多
正為您匹配相似的精品文檔
關于我們 - 網站聲明 - 網站地圖 - 資源地圖 - 友情鏈接 - 網站客服 - 聯系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網版權所有   聯系電話:18123376007

備案號:ICP2024067431-1 川公網安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對上載內容本身不做任何修改或編輯。若文檔所含內容侵犯了您的版權或隱私,請立即通知裝配圖網,我們立即給予刪除!