




已閱讀5頁,還剩4頁未讀, 繼續(xù)免費(fèi)閱讀
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
數(shù)據(jù)結(jié)構(gòu)課程 20112012年度 第1學(xué)期實(shí)驗(yàn)考核題目:順序表的實(shí)現(xiàn) 院系:學(xué)號(hào): 姓名: 任課教師: 完成日期:年月日一. 預(yù)習(xí)準(zhǔn)備1. 實(shí)驗(yàn)?zāi)康?(1).理解線性表的概念;(2).理解順序表存儲(chǔ)結(jié)構(gòu)概念和特點(diǎn); (3).掌握順序表存儲(chǔ)結(jié)構(gòu)的建立、插入、刪除、查詢和輸出基本操作算法。 2. 實(shí)驗(yàn)環(huán)境Widows 操作系統(tǒng)、Microsoft Visual Studio 2008、C+語言3. 實(shí)驗(yàn)內(nèi)容和要求(1)實(shí)驗(yàn)內(nèi)容A. 利用switch函數(shù)設(shè)計(jì)一個(gè)如下目錄添加新聯(lián)系人 刪除聯(lián)系人查找聯(lián)系人修改信息 顯示所有聯(lián)系人關(guān)閉通訊錄B. 建立一個(gè)如下所示的班級(jí)通訊錄:學(xué)號(hào) 姓名 性別 電話號(hào)碼 20001 張三 男 20 20002李四男 22 使用結(jié)構(gòu)體,用順序表完成以下內(nèi)容:a.初始化線性表為空; b.依次輸入數(shù)據(jù)元素;(由鍵盤輸入);c.完成數(shù)據(jù)元素的插入、刪除、修改操作;d.取第i個(gè)數(shù)據(jù)元素;e.依次顯示當(dāng)前線性表中的數(shù)據(jù)元素。(2) 實(shí)驗(yàn)要求掌握順序表的定義與實(shí)現(xiàn),包括查找、插入、刪除算法的實(shí)現(xiàn)。二. 實(shí)驗(yàn)過程1. 實(shí)驗(yàn)中的關(guān)鍵語句在整個(gè)實(shí)驗(yàn)中要執(zhí)行8個(gè)過程:(1) .調(diào)用構(gòu)造函數(shù)SeqList(),初始化順序表;(2) 輸出目錄提示,輸入相應(yīng)的序號(hào),調(diào)用switch函數(shù)來實(shí)現(xiàn)相應(yīng)功能: .調(diào)用函數(shù) void Insert(int i, T x) ,從鍵盤向順序表中輸入數(shù)據(jù)元素和位置,并按所輸入的位置進(jìn)行插入; .調(diào)用函數(shù)T Delete(int i),刪除順序表中指定位置的數(shù)據(jù)元素; .調(diào)用函數(shù)void PrintPerson(T x),讀取指定姓名的數(shù)據(jù)元素并顯示在屏幕上; .調(diào)用函數(shù)T Delete(int i)和void Insert(int i, T x) 來實(shí)現(xiàn)數(shù)據(jù)元素的修改。 .調(diào)用函數(shù)void PrintList( ),顯示當(dāng)前順序表中的數(shù)據(jù)元素在屏幕上;通過這六個(gè)過程的執(zhí)行,完成順序表的操作。 .調(diào)用exit(0)語句,進(jìn)行退出。三. 實(shí)驗(yàn)總結(jié) 1. 實(shí)驗(yàn)程序(詳細(xì)設(shè)計(jì))1.1主函數(shù)部分:(main.cpp)#include #include function.cpp #include using namespace std;int main() int which; int i; string num; /學(xué)號(hào) string name; /姓名 string PhoneNum; /電話號(hào)碼 string sex; /性別 int where; /位置 int length; /順序表長(zhǎng)度 SeqList a; AddressBook AB;while (1) cout tendl; cout t 班級(jí)通訊錄 endl; cout t 添加新聯(lián)系人 刪除聯(lián)系人 endl; coutt endl; coutt endl; cout t 查找聯(lián)系人 修改信息 endl; coutt endl; coutt endl; cout t 顯示所有聯(lián)系人 關(guān)閉通訊錄 endl; coutt endl; cout tendl; cout which; switch(which) case 1: coutn; a.PrintList( ); coutAB.num; coutAB.name; coutAB.PhoneNum; coutAB.sex; coutwhere; length=a.Length(); try a.Insert( where, AB); catch(char* wrong) cout wrong; break; case 2: coutn; a.PrintList( ); cout 需要?jiǎng)h除的聯(lián)系人的位置 where; try a.Delete(where); cout 已經(jīng)刪除; catch(char* wrong) cout wrong; break; case 3: cout 請(qǐng)輸入聯(lián)系人姓名: name; length =a.Length(); for (i=0; ilength; i+) AB=a.Get(i); if (AB.name=name) try a.PrintPerson(AB); catch(char* wrong) cout wrong; else cout查找失敗n; break; case 4: coutn; a.PrintList( ); coutwhere; coutAB.num; coutn; coutAB.name; coutn; coutAB.PhoneNum; coutn; coutAB.sex; a.Delete(where); a.Insert( where, AB); break; case 5: a.PrintList(); break; case 6: couttt安全退出endl; exit(0); break; default:break; 1.2函數(shù)定義部分:(function.cpp)#include AddressBook.htemplateSeqList:SeqList(T a,int n)int i;if (nMaxSize) throw 參數(shù)非法;for (i=0; in; i+) datai=ai; length=n;template void SeqList:Insert(int i, T x) int j; if (length=MaxSize) throw 上溢; if (ilength+1) throw 位置錯(cuò)誤; for (j=length; j=i; j-)dataj=dataj-1; datai-1=x; length+;template T SeqList:Get(int i) if (i=0 & i=length-1) return datai; else T ad; return ad; template T SeqList:Delete(int i) int j; if (length=0 ) throw 下溢; if (ilength) throw 位置錯(cuò)誤; T x=datai-1; for (j=i; jlength; j+) dataj-1=dataj; length-; return x;template void SeqList:PrintList( ) int i; for (i=0; ilength; i+) int j;j=i;j+;cout 位置:j n;cout 學(xué)號(hào): datai.num 姓名: n; cout 性別: datai.sex 電話號(hào)碼: datai.PhoneNum n; cout n; template void SeqList:PrintPerson(T x) cout 學(xué)號(hào): x.num 姓名: n; cout 性別: x.sex 電話號(hào)碼: x.PhoneNum n; cout n;1.3接口部分:(AddressBook.h) #include using namespace std; const int MaxSize=100; struct AddressBookstring num;string name;string PhoneNum;string sex;templateclass SeqListpublic:SeqList()length=0;SeqList(T a,int n); SeqList( ) int Length()return length;T Get(int i); void Insert(int i, T x); T Delete(int i); void PrintList( ); void PrintPers
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 幼兒園秤桿課件
- 體育運(yùn)動(dòng)訓(xùn)練理論與實(shí)踐知識(shí)梳理
- 蛇咬傷的護(hù)理查房
- 普外科一病一品護(hù)理匯報(bào)
- 2025年安徽貨運(yùn)從業(yè)模擬考試
- 數(shù)字版權(quán)保護(hù)系統(tǒng)協(xié)議
- 高級(jí)管理人員股權(quán)激勵(lì)計(jì)劃協(xié)議
- 創(chuàng)業(yè)公司行業(yè)分布表
- 2025屆江蘇省蘇州市葛江中學(xué)英語八下期末復(fù)習(xí)檢測(cè)模擬試題含答案
- 神奇的畫筆寫物類作文(8篇)
- 企業(yè)政策宣講活動(dòng)方案
- 自來水考試試題大題及答案
- (2025)發(fā)展對(duì)象考試題庫與答案
- 北京師范大學(xué)《微積分(2)》2023-2024學(xué)年第二學(xué)期期末試卷
- CJ/T 410-2012隔油提升一體化設(shè)備
- 鴻蒙模擬試題及答案
- 2025屆湖南長(zhǎng)沙雅禮實(shí)驗(yàn)中學(xué)七年級(jí)數(shù)學(xué)第二學(xué)期期末學(xué)業(yè)水平測(cè)試試題含解析
- 天津市濱海新區(qū)第四共同體2025年八下物理期末復(fù)習(xí)檢測(cè)試題含解析
- 客服投訴處理技巧培訓(xùn)
- 醫(yī)學(xué)檢驗(yàn)倫理規(guī)范與實(shí)踐
- TCWEA6-2019水利水電工程施工期度汛方案編制導(dǎo)則
評(píng)論
0/150
提交評(píng)論