數(shù)據結構上機實驗指導_第1頁
數(shù)據結構上機實驗指導_第2頁
數(shù)據結構上機實驗指導_第3頁
數(shù)據結構上機實驗指導_第4頁
數(shù)據結構上機實驗指導_第5頁
已閱讀5頁,還剩2頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、數(shù)據結構課程上機實驗指導書實驗【實驗名稱】 順序表的基本算法【實驗目的】 創(chuàng)建一個順序表,掌握線性表順序存儲的特點。設計和驗證順序表的查找、 插入、 刪除 算法。【實驗要求】( 1) 從鍵盤讀入一組整數(shù), 按輸入順序形成順序表。 并將創(chuàng)建好的順序表元素依次 打印在屏幕上。(2)設計一個帶選擇菜單的主函數(shù), 菜單中具備任意選擇刪除、 插入、 查找數(shù)據元 素的功能。( 3) 當選擇刪除功能時, 從鍵盤讀入欲刪除的元素位置或元素值, 按指定方式刪除; 當選擇插入功能時,從鍵盤讀入新元素值和被插入位置,在指定位置插入; 當選擇查找功能時,從鍵盤讀入欲查找的元素值,返回其位置序號。( 4) 每種操作結束

2、后,都能在屏幕上打印出此時順序表元素的遍歷結果。【實驗步驟】1、實驗前先寫好算法。2、上機編寫程序。3、編譯。4、調試。例程: 書上參考算法 2-1,2-4,2-5,2-6,2-8!帶菜單的主函數(shù)參考書上 2.5 綜合實例! 注意:順序表的結構體!typedef structdatatype itemslistsize;int length;SpList;實驗二【實驗名稱】 單鏈表的基本算法【實驗目的】創(chuàng)建一個單鏈表,掌握線性表鏈式存儲的特點。設計和驗證鏈表的查找、插入、刪除、 求表長的算法。【實驗要求】( 1) 從鍵盤讀入一組整數(shù), 按輸入順序形成單鏈表。 并將創(chuàng)建好的單鏈表元素依次 打印在

3、屏幕上。 (注意:選擇頭插法或者尾插法! )(2) 設計一個帶選擇功能菜單的主函數(shù), 菜單中至少具備任意選擇刪除、 插入、 查 找數(shù)據元素,和求單鏈表表長等幾項功能。( 3) 當選擇刪除功能時, 從鍵盤讀入欲刪除的元素位置, 按指定位置刪除; 當選擇 插入功能時,從鍵盤讀入新元素值和被插入位置,在指定位置插入;當選擇 查找功能時,從鍵盤讀入欲查找的元素值,返回其位置序號;當選擇求表長 功能時,返回該單鏈表表長的數(shù)值。( 4) 每種操作結束后,都能在屏幕上打印出此時單鏈表元素的遍歷結果?!緦嶒灢襟E】1、實驗前先寫好算法。2、上機編寫程序。3、編譯。4、調試。例程: 書上參考算法 2-10,2-1

4、2, 2-13,2-15,2-17!帶菜單的主函數(shù)參考書上 2.5 綜合實 例!另外,注意,指針的初始化!指針的操作必須謹慎!鏈表的結構體如下:typedef struct NodeDatatype ch;struct Node *next;LNode, *Pnode, *Linklist;實驗三【實驗名稱】 回文判斷的算法 【實驗目的】利用棧和隊列的操作來實現(xiàn)對字符序列是否是一個回文序列的判斷。設計和驗證入棧、 出棧及入隊、出隊的算法?!緦嶒炓蟆浚?1)從鍵盤讀入一組字符序列,按輸入順序入隊列到鏈式隊列 A 中。并將創(chuàng)建好的 A 隊列中元素依次遍歷,打印在屏幕上。( 2)將字符序列從 A

5、隊列出隊列,壓入到一個順序棧 B 中。(3)再將字符序列從順序棧 B 中出棧,所有元素依次遍歷,打印在屏幕上。(4)將 A,B 的元素值逐一比較,判斷是否一致。若一致則是回文,并將判定結果打印到屏幕上。注意:指定采用順序棧和鏈隊列的結構來實現(xiàn)?!緦嶒灢襟E】1、設計算法2、編寫程序3、編譯4、調試例程: 棧的各種操作如算法3-3, 3-4,隊列的操作比如算法3-15, 3-16 等等??赡苡玫降淖址瘮?shù),比如 strlen () , strcmp ()等。順序棧:typedef struct char itemsstacksize; int top;SqStack;鏈隊列:typedef st

6、ruct QNode char data; struct QNode *next;LQNode , *PQNode;typedef structPQNode front ,rear;LinkQueue;實驗四【實驗名稱】 哈希查找【實驗目的】驗證哈希查找算法【實驗要求】(1) 先創(chuàng)建一個數(shù)組類型的順序表,以 1 作為結束。從鍵盤輸入一組數(shù)據元素后, 按順序表的遍歷輸出,并打印顯示。( 2) 再以哈希函數(shù)方式, 將數(shù)據元素放入哈希表中, 并將哈希表輸出, 并打印顯示。 采用線性探測法處理沖突。 注意:哈希表的下標和數(shù)據內容都顯示到屏幕上。( 3) 輸入需要查找的任意元素的關鍵字,查找并輸出該元素

7、的位置下標序列號。若 有沖突,顯示它原來的下標位置和新的下標位置。若沒有,也將找不到的信息 反饋出來。注意:用線性探測法處理沖突?!緦嶒灢襟E】1、設計算法2、編寫程序3、編譯4、調試例程:參考書上的算法 P274-277 的多個算法。比如:哈希表的地址區(qū)間為 0-17,哈希函數(shù)為 h(key)=K%17 。采用線性探測法處理沖突。 若給定關鍵字序列: 26,25,72,38,8,18,59。請問搜索 59 在幾號下標位置,需要查找 多少次?實驗五實驗名稱】 排序操作實驗目的】驗證各種排序算法。在調試中體會排序過程。實驗要求】( 1) 從鍵盤讀入一組無序數(shù)據,按輸入順序先創(chuàng)建一個線性表。( 2)

8、 用帶菜單的主函數(shù)任意選擇一種排序算法將該表進行遞增排序。 實驗步驟】1、設計算法2、編寫程序3、編譯4、調試例程: 冒泡排序法、直接選擇排序法、直接插入排序實驗六(綜合)【實驗名稱】 學生成績表的操作【實驗目的】加強線性表操作的訓練。【實驗要求】( 1) 先創(chuàng)建一個數(shù)組類型或鏈表類型的線性表,其中每個數(shù)據元素包括的數(shù)據項內 容有:學生學號,姓名,及語文,數(shù)學,英語三門課程的分數(shù)。( 2) 利用鍵盤輸入數(shù)字在主函數(shù)中選擇菜單的功能,可以對學生成績表進行多項操 作,比如:增加一個學生的信息,刪除一個學生的信息,查找一個學生的信息, 或者按某門課程分數(shù)進行學生的排序等等。( 3) 每個操作完成后,在屏幕上將該線性表的數(shù)值完全輸出。【實驗步驟】5、設計算法6、編寫程序7、編譯8、調試例程: 線性表的各種操作數(shù)據結構課程實驗報告要求實驗題目班級姓名學號日期、需求分析1.2.3.程序的功能; 輸入輸出的要求; 測試數(shù)據。、概要設計1.2.本程序所用的抽象數(shù)據類型的定義; 主

溫馨提示

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

評論

0/150

提交評論