




已閱讀5頁,還剩6頁未讀, 繼續免費閱讀
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
實驗一、線性表的實現及操作(一)一、實驗目的了解和掌握線性表的順序存儲結構;掌握用C語言上機調試線性表的基本方法;掌握線性表的基本操作:插入、刪除、查找以及線性表合并等運算在順序存儲結構和鏈接存儲結構上的運算,以及對相應算法的性能分析。二、實驗要求給定一段程序代碼,程序代碼所完成的功能為:(1)建立一個線性表;(2)依次輸入數據元素1,2,3,4,5,6,7,8,9,10;(3)刪除數據元素5;(4)依次顯示當前線性表中的數據元素。假設該線性表的數據元素個數在最壞情況下不會超過100個,要求使用順序表。程序中有3處錯誤的地方,有標識,屬于邏輯錯誤,對照書中的代碼仔細分析后,要求同學們修改錯誤的代碼,修改后上機調試得到正確的運行結果。(1)需求分析: 這份實驗報告為所有必做題的實驗報告。包括實驗一順序表建立、插入、刪除等基本操作,實驗二單鏈表的建立、插入、刪除等基本操作,實驗四二叉樹的基本操作:樹的建立、前序、中序、后序遍歷及實驗六圖的遍歷:深度優先和廣度優先。這四份基礎性的實驗為改錯性質,將每個實驗題目中的錯誤改正過來并通過調試,有助于對基礎知識的理解與強化記憶。(2)概要設計: 實驗一為對順序線性表實現插入,刪除,查找等基本操作。 需要用到的語句包括void ListInitiate(SeqList *L) int ListInsert(SeqList *L, int i, DataType x) int ListDelete(SeqList *L, int i, DataType *x) int ListGet(SeqList L, int i, DataType *x)等。 實驗二是對單鏈表進行建立,插入,刪除等基本操作。 需要的語句為void ListInitiate(SeqList *L) int ListInsert(SeqList *L, int i, DataType x) int ListDelete(SeqList *L, int i, DataType *x) int ListGet(SeqList L, int i, DataType *x)等。 實驗四為二叉樹,要求建立一個二叉樹,并實現前序,中序及后序的遍歷。 所需語句包括void ListInitiate(SeqList *L) int ListInsert(SeqList *L, int i, DataType x) int ListDelete(SeqList *L, int i, DataType *x) int ListGet(SeqList L, int i, DataType *x)等。 實驗六的內容是圖的遍歷包括鄰接矩陣和鄰接鏈表兩種方法。三、程序代碼(更正后的代碼)#include #define MaxSize 100typedef int DataType;typedef structDataType listMaxSize;int size; SeqList;void ListInitiate(SeqList *L)/*初始化順序表L*/L-size = 0;/*定義初始數據元素個數*/ int ListLength(SeqList L)/*返回順序表L的當前數據元素個數*/return L.size;int ListInsert(SeqList *L, int i, DataType x) /*在順序表L的位置i(0 i size)前插入數據元素值x*/ /*插入成功返回1,插入失敗返回0*/int j;if(L-size = MaxSize)printf(順序表已滿無法插入! n);return 0;else if(i L-size )printf(參數i不合法! n);return 0;else for(j = L-size; j i; j-) L-listj = L-listj;/*為插入做準備*/L-listi = x;/*插入*/L-size +;/*元素個數加1*/return 1;int ListDelete(SeqList *L, int i, DataType *x)/*刪除順序表L中位置i(0 i size - 1)的數據元素值并存放到參數x中*/*刪除成功返回1,刪除失敗返回0*/int j;if(L-size = 0)printf(順序表已空無數據元素可刪! n);return 0;else if(i L-size-1)printf(參數i不合法);return 0;else/此段程序有一處錯誤*x = L-listi;/*保存刪除的元素到參數x中*/for(j = i +1; j size-1; j+) L-listj = L-listj-1;/*依次前移*/L-size-;/*數據元素個數減1*/return 1;int ListGet(SeqList L, int i, DataType *x)/*取順序表L中第i個數據元素的值存于x中,成功則返回1,失敗返回0*/if(i L.size-1)printf(參數i不合法! n);return 0;else*x = L.listi;return 1;void main(void) SeqList myList; int i , x; ListInitiate(&myList); for(i = 0; i 10; i+) ListInsert(&myList, i, i+1); ListDelete(&myList, 4, &x); for(i = 0; i ListLength(myList); i+) ListGet( myList, i, &x); /此段程序有一處錯誤printf(%d , x); 測試結果:線性表的實現及操作(二)一、實驗目的了解和掌握線性表的鏈式存儲結構;掌握用C語言上機調試線性表的基本方法;掌握線性表的基本操作:插入、刪除、查找以及線性表合并等運算在順序存儲結構和鏈接存儲結構上的運算,以及對相應算法的性能分析。二、實驗要求給定一段程序代碼,程序代碼所完成的功能為:(1)建立一個線性表;(2)依次輸入數據元素1,2,3,4,5,6,7,8,9,10;(3)刪除數據元素5;(4)依次顯示當前線性表中的數據元素。假設該線性表的數據元素個數在最壞情況下不會超過100個,要求使用單鏈表。程序中有3處錯誤的地方,有標識,屬于邏輯錯誤,對照書中的代碼仔細分析后,要求同學們修改錯誤的代碼,上機調試并得到正確的運行結果。三、程序代碼:(更正后的結果)#include /*該文件包含pringtf()等函數*/#include /*該文件包含exit()等函數*/#include /*該文件包含malloc()等函數*/typedef int DataType;/*定義DataType為int*/typedef struct NodeDataType data;struct Node *next; SLNode;void ListInitiate(SLNode *head)/*初始化*/*如果有內存空間,申請頭結點空間并使頭指針head指向頭結點*/if(*head = (SLNode *)malloc(sizeof(SLNode) = NULL) exit(1);(*head)-next = NULL;/*置鏈尾標記NULL */int ListLength(SLNode *head)SLNode *p = head;/*p指向首元結點*/int size = 0;/*size初始為0*/while(p-next != NULL)/*循環計數*/p = p-next;size +;return size;int ListInsert(SLNode *head, int i, DataType x)/*在帶頭結點的單鏈表head的數據元素ai(0 i size)結點前*/*插入一個存放數據元素x的結點*/SLNode *p, *q;int j;p = head; /*p指向首元結點*/j = -1;/*j初始為-1*/while(p-next != NULL & j next;j+;if(j != i - 1)printf(插入位置參數錯!);return 0;/*生成新結點由指針q指示*/if(q = (SLNode *)malloc(sizeof(SLNode) = NULL) exit(1);q-data = x;/此段程序有一處錯誤p-next = q-next;/*給指針q-next賦值*/p-next = q;/*給指針p-next重新賦值*/return 1;int ListDelete(SLNode *head, int i, DataType *x)/*刪除帶頭結點的單鏈表head的數據元素ai(0 i size - 1)結點*/*刪除結點的數據元素域值由x帶回。刪除成功時返回1;失敗返回0*/SLNode *p, *s;int j;p = head; /*p指向首元結點*/j = -1;/*j初始為-1*/while(p-next != NULL & p-next-next!= NULL & j next;j+;if(j != i - 1)printf(插入位置參數錯!);return 0;/此段程序有一處錯誤s = p-next; /*指針s指向數據元素ai結點*/*x = s-data;/*把指針s所指結點的數據元素域值賦予x*/p-next = s-next;/*把數據元素ai結點從單鏈表中刪除指*/free(s);/*釋放指針s所指結點的內存空間*/return 1;int ListGet(SLNode *head, int i, DataType *x)/*取數據元素ai和刪除函數類同,只是不刪除數據元素ai結點*/SLNode *p;int j;p = head;j = -1;while(p-next != NULL & j next;j+;if(j != i)printf(取元素位置參數錯!);return 0;/此段程序有一處錯誤*x = p-data;return 1;void Destroy(SLNode *head)SLNode *p, *p1;p = *head;while(p != NULL)p1 = p;p = p-next;free(p1);*head = NULL;void main(void)SLNode *head;int i , x;ListInitiate(&head);/*初始化*/for(i = 0; i 10; i+)if(ListInsert(head, i, i+1) = 0) /*插入10
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 交通噪聲屏障工程可行性研究報告(范文參考)
- 工業機器人升級項目可行性研究報告(范文模板)
- 新疆維吾爾自治區塔城地區塔城市2022-2023學年高二上學期期中英語 含解析
- 重慶市黔江中學2023-2024學年高一上學期10月月考語文卷 含解析
- 幼兒園乘公交車安全教育
- 鄭州黃河護理職業學院《地下水水力學》2023-2024學年第二學期期末試卷
- 北京交通職業技術學院《黑白木刻版畫基礎》2023-2024學年第二學期期末試卷
- 綿陽飛行職業學院《商務大數據分析》2023-2024學年第二學期期末試卷
- 黎明職業大學《材料分析與測試技術實驗》2023-2024學年第二學期期末試卷
- 大連航運職業技術學院《社會經濟統計學》2023-2024學年第二學期期末試卷
- 自愿離婚協議書電子版
- 2025年廣東省汕頭市澄海區中考一模數學試題(含答案)
- 高考英語必背688個高頻詞匯清單
- 浙江開放大學2025年《社會保障學》形考任務1答案
- 統編版二年級語文下冊第五單元自測卷(含答案)
- 北京市矢量地圖-可改顏色
- 階梯型獨立基礎(承臺)配筋率驗算
- 2010年某市人行天橋鋼結構制作安裝合同
- 新概念課堂筆記 第一冊 Lesson 127-128
- 《汽車板材料物流配送服務技術規范》團體標準
- 四季酒店[Four Seasons]酒店培訓手冊(英)P48
評論
0/150
提交評論