課程設(shè)計(jì)--《哈希表的操作》設(shè)計(jì)報(bào)告_第1頁(yè)
已閱讀1頁(yè),還剩14頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p>  《哈希表的操作》設(shè)計(jì)報(bào)告</p><p><b>  一 目的</b></p><p>  通過(guò)此次課程設(shè)計(jì),讓學(xué)生充分掌握對(duì)哈希表的有關(guān)操作,例如除留余數(shù)法的運(yùn)用,處理沖突的三個(gè)辦法:線性探測(cè)再散列,二次探測(cè)再散列,連地址法等。加深學(xué)生對(duì)于哈希表這種獨(dú)特存儲(chǔ)方式(區(qū)別于線性存儲(chǔ)和鏈?zhǔn)酱鎯?chǔ))的理解,和幾種算法之間的優(yōu)越性的體會(huì)。 </p&

2、gt;<p><b>  二 需求分析</b></p><p><b>  1、功能需求</b></p><p> ?、伲脩?hù)能夠自定義輸入單詞,存入哈希表里;</p><p> ?、冢脩?hù)能夠?qū)Ξ?dāng)前哈希表進(jìn)行管理。操作內(nèi)容包括:查看當(dāng)前哈希表、搜索某個(gè)單詞、插入任意單詞、刪除表中某個(gè)單詞、查看當(dāng)前表的平均

3、搜索長(zhǎng)度、置空當(dāng)前哈希表。</p><p> ?、郏绦蛴辛己玫慕换ソ缑?,有操作提示和出錯(cuò)提示,方便用戶(hù)使用和進(jìn)出入程序。</p><p><b>  2、程序約束</b></p><p> ?、伲1淼纳⒘蟹椒槌粲鄶?shù)法,處理沖突的辦法為線性探測(cè)在散列。</p><p> ?、冢褂肅/C++語(yǔ)言編寫(xiě),程序模塊化設(shè)

4、計(jì)。</p><p><b>  三 概要設(shè)計(jì)</b></p><p><b>  1、模塊設(shè)計(jì)</b></p><p>  程序分為主程序模塊和哈希表類(lèi)定義模塊,主程序存放在main.app中,哈希表類(lèi)存放在HashTable.h頭文件中。</p><p><b>  ①.主程序模塊&

5、lt;/b></p><p>  用于數(shù)據(jù)和DOS用戶(hù)界面的初始化,主函數(shù)mai()內(nèi)部定義子函數(shù)function(),調(diào)用哈希表類(lèi)中的各個(gè)功能函數(shù)。</p><p><b> ?、冢1眍?lèi)定義</b></p><p>  Calculate(string s) 單詞key值計(jì)算函數(shù),類(lèi)友元<

6、;/p><p>  形參s傳送輸入的單詞。由于單詞為string型,不方便直接拿來(lái)參與取余數(shù)計(jì)算,故用計(jì)算函數(shù)求出一個(gè)key來(lái),同時(shí)可以減少?zèng)_突(字母相同的單詞key有可能不同)。</p><p>  FindPos(int key,string value) 地址查找函數(shù),類(lèi)成員</p><p>  key傳送計(jì)算出的單詞的關(guān)鍵值,value傳送輸入的單詞,下同

7、。此函數(shù)為查找、插入、刪除等函數(shù)提供地址搜索服務(wù)。</p><p>  Search(int key,string value) 查找函數(shù),類(lèi)成員</p><p>  Insert(string value) 插入函數(shù),類(lèi)成員</p><p>  Remove(int key,string value) 刪除函數(shù)

8、,類(lèi)成員</p><p>  makeEmpty() 置空哈希表函數(shù),類(lèi)成員</p><p>  getInfo(int address) 獲取某個(gè)地址中元素的信息,類(lèi)成員</p><p>  形參address是哈希表中某元素的地址(數(shù)組下標(biāo)),通過(guò)key % divitor

9、得到</p><p>  getSize(HashTable HT) 獲取哈希表存儲(chǔ)情況,類(lèi)友員</p><p>  ASL(HashTable HT) 平均查找長(zhǎng)度計(jì)算函數(shù),類(lèi)友元</p><p><b>  四 詳細(xì)設(shè)計(jì)</b></p><p><b&g

10、t;  1、主要功能實(shí)現(xiàn)</b></p><p> ?、伲侄x:#define DefaultSize 30 數(shù)組最大容量</p><p>  divitor 取余除數(shù),設(shè)為29(≤30的最大質(zhì)數(shù))</p><p> ?、冢畣卧~key計(jì)算:</p

11、><p>  int Calculate(string s){</p><p>  //key計(jì)算函數(shù):word前5個(gè)字符的ASCII碼 + 單詞長(zhǎng)度</p><p>  //不足5個(gè)字符的word,用所有字符的ASCII碼 + 單詞長(zhǎng)度</p><p>  int k=0,len; </p><p>  len=s.le

12、ngth();</p><p>  if(len<5){</p><p>  for(unsigned int i=0;i<s.length();i++) k+=(int)s[i]; }</p><p><b>  else{</b></p><p>  for(int i=0;i<=4;i++) k+

13、=(int)s[i]; }</p><p><b>  k+=len;</b></p><p><b>  return k;</b></p><p><b>  } </b></p><p><b> ?、郏刂凡檎遥?lt;/b></p>&l

14、t;p>  int HashTable::FindPos(int key,string value) const{ </p><p>  //搜索一個(gè)散列表中關(guān)鍵碼與key匹配的元素,搜索成功,則函數(shù)返回改元素的位置</p><p>  //否則返回插入點(diǎn)(如果有足夠空間的話)</p><p>  int address= key % divit

15、or;</p><p>  int j = address;</p><p><b>  do{</b></p><p>  if(info[j]==Empty || (info[j]==Active && ht[j]==value)){ t1++;return j;} //找到</p><p> 

16、 else { j=(j+1) % TableSize; t1++; } //當(dāng)做循環(huán)表處理,找出下一個(gè)空地址</p><p>  }while (j != address); </p><p>  return j; //轉(zhuǎn)一圈回到起點(diǎn),表已

17、滿(mǎn),失敗</p><p>  } //t1在這個(gè)函數(shù)體里面增加的量△t1為某一元素探查的次數(shù)</p><p>  ④.搜索、插入、刪除函數(shù)相同結(jié)構(gòu):</p><p>  Type Name(type1 paramater1, type2 paramater2){</p><p>  //調(diào)用FindPos(type1 paramater1,

18、type2 paramater2)</p><p>  //檢查FindPos返回值,并對(duì)此作出相應(yīng)判斷</p><p>  //根據(jù)以上內(nèi)容作出處理</p><p><b>  //返回</b></p><p><b>  }</b></p><p><b>  

19、⑤.ASL設(shè)計(jì):</b></p><p>  第一步:設(shè)立全局變量t1,t2,分別代表成功和不成功的ASL公式的分子。</p><p>  第二步:在FindPos處設(shè)立一個(gè)監(jiān)聽(tīng)變量t,每次查找t自加1,直到查找到合適地址。t的增量△t就是這個(gè)元素的查找次數(shù)。</p><p>  第三步:在Insert處用t監(jiān)聽(tīng),插入成功t不變,失敗則t自減1。<

20、/p><p>  第四步:在Remove處用t監(jiān)聽(tīng),首先將t賦值給一個(gè)中間變量temp,經(jīng)過(guò)FindPos地址查找后,t的增量△t=t-temp。刪除這個(gè)元素,意味著這個(gè)元素的t要減去這元素的查找次數(shù),即t-2*(t-temp)。</p><p>  ASLsucc = t1 / 輸入單詞的個(gè)數(shù)(或已用地址的數(shù)量)</p><p>  ASLunsucc = t2 /

21、表長(zhǎng) , t2的計(jì)算如下:</p><p><b>  2、流程圖</b></p><p><b>  五 調(diào)試分析</b></p><p>  1、本次課程設(shè)計(jì)采用的是除留余數(shù)法構(gòu)造了哈希表,除數(shù)的選擇很重要。如果選得不好,會(huì)造成很多沖突,浪費(fèi)時(shí)間和空間代價(jià)。例如,本次設(shè)計(jì)的哈希表最大長(zhǎng)度為30,余數(shù)如果取得較小,例

22、如23,17等,相比起最接近30的29來(lái)說(shuō),會(huì)使得一部分元素容易形成堆積,平均搜索長(zhǎng)度變大,而且取余的時(shí)間也會(huì)更長(zhǎng)。</p><p>  2、本次設(shè)計(jì)處理沖突采用了線性探測(cè)再散列的辦法。相比起同時(shí)閉散列方法的二次探測(cè)再散列來(lái)說(shuō),優(yōu)點(diǎn)在于功能簡(jiǎn)單易操作性;缺點(diǎn)是當(dāng)數(shù)據(jù)量逐漸加大時(shí),前者的平均查找長(zhǎng)度會(huì)逐漸比后者大。</p><p>  3、做為閉散列方法處理沖突問(wèn)題,不能像連地址法那樣的開(kāi)放

23、地址法一樣,隨意的用物理刪除方法刪除表里的元素。否則容易引起搜索鏈的中斷,使得該元素后面發(fā)生沖突的元素?zé)o法查找到,造成程序和實(shí)際情況有誤。</p><p>  4、在概要設(shè)計(jì)的階段發(fā)現(xiàn),無(wú)論是搜索、插入還是刪除,首先都要對(duì)元素進(jìn)行尋址操作,因此獨(dú)立設(shè)立一個(gè)尋址函數(shù)FindPos,供以上三個(gè)函數(shù)共用,以減少代碼的重復(fù)。</p><p><b>  六 測(cè)試結(jié)果</b>

24、</p><p><b>  1.單詞輸入</b></p><p><b>  2.表內(nèi)存儲(chǔ)情況</b></p><p>  3.輸入完畢立即測(cè)試ASL的情況</p><p><b>  4查找測(cè)試</b></p><p><b>  5. 插

25、入刪除測(cè)試</b></p><p>  測(cè)試結(jié)果:沒(méi)有發(fā)現(xiàn)錯(cuò)誤。</p><p><b>  七 用戶(hù)使用說(shuō)明</b></p><p><b>  1、功能使用說(shuō)明</b></p><p>  ①.查課表:查看當(dāng)前哈希表的存儲(chǔ)情況</p><p>  ②.搜索:

26、輸入一個(gè)單詞,查詢(xún)表內(nèi)的情況。不支持key查詢(xún),因?yàn)橄嗤膋ey可能有不同的單詞對(duì)應(yīng),例如”pa”和”le”,key都是211。</p><p> ?、郏迦耄狠斎雴卧~,插入到哈希表中。插入后會(huì)立即顯示插入元素的情況。</p><p> ?、埽畡h除:輸入單詞,在表中搜索,如果存在則刪除,不存在則提示不存在或者已刪除。不支持輸入key進(jìn)行刪除,原因同②。暫時(shí)不支持直接輸入地址進(jìn)行刪除。<

27、;/p><p> ?、荩@示ASL:查看當(dāng)前表中的ASL值。</p><p> ?、蓿每毡恚簩?dāng)前表初始化為一張空表。</p><p><b>  2、注意事項(xiàng)</b></p><p>  本次設(shè)計(jì)重點(diǎn)在對(duì)哈希表的處理上,沒(méi)有對(duì)選擇界面進(jìn)行很有效的出錯(cuò)處理,請(qǐng)勿在輸入數(shù)字時(shí)輸入其他字符,以免出現(xiàn)死循環(huán)等錯(cuò)誤。</p&

28、gt;<p><b>  八 課程設(shè)計(jì)總結(jié)</b></p><p><b>  1、目的達(dá)成百分比</b></p><p>  通過(guò)此次的課程設(shè)計(jì),我已經(jīng)基本了解并掌握了哈希表的基本操作方法,對(duì)常用的散列方法(如:除留余數(shù)法)、處理沖突的方法(如:線性探測(cè)和二次探測(cè))有了更深的認(rèn)識(shí)和體會(huì),對(duì)開(kāi)散列法(鏈地址法)也有了進(jìn)一步的了解。

29、此次課程設(shè)計(jì)目的達(dá)成的百分比我給自己評(píng)定在75%~85%。</p><p><b>  2、心得體會(huì)</b></p><p> ?、伲敬蔚恼n程設(shè)計(jì)并不是很難,都是課上所講解過(guò)的基本內(nèi)容。容易出錯(cuò)的地方應(yīng)該是一些細(xì)節(jié)方面。比如ASL的計(jì)算,機(jī)器并沒(méi)有人腦那么靈活,會(huì)過(guò)濾掉插入和刪除所帶來(lái)的影響,所以在插入或者刪除時(shí)要特別注意ASL值得變化,防止結(jié)果有誤。</p&

30、gt;<p> ?、冢敬握n程設(shè)計(jì)可以用動(dòng)態(tài)數(shù)組來(lái)代替目前的靜態(tài)數(shù)組,達(dá)到更實(shí)用的效果。還可以將現(xiàn)在的類(lèi)寫(xiě)成模板類(lèi)形式,為以后各種元素類(lèi)型的哈希表提供類(lèi)模板。</p><p><b>  附件:</b></p><p><b>  1、源代碼</b></p><p>  ①.頭文件hashtable.h<

31、;/p><p>  #include <iostream></p><p>  using namespace std;</p><p>  #define Active 1</p><p>  #define Empty 0</p><p>  #define Deleted -1</p>&l

32、t;p>  const int DefaultSize = 30;</p><p>  //enum KindOfStatus {Active ,Empty ,Deleted};</p><p>  int t1,t2; //t1:每個(gè)已有元素的探查次數(shù)的總和 t2:每個(gè)新元素查找可用地址的次數(shù)總和 (t/time)</p><p>  class H

33、ashTable{</p><p><b>  public:</b></p><p>  HashTable(const int d,int sz=DefaultSize); //構(gòu)造函數(shù)聲明</p><p>  bool Search(int key,string value); //搜索<

34、/p><p>  int Insert(string value); //插入</p><p>  bool Remove(int key,string value); //刪除</p><p>  void makeEmpty();

35、 //置空</p><p>  void getInfo(int address); //一開(kāi)始是用的友元的,但是不知道為什么訪問(wèn)Private總是報(bào)錯(cuò)</p><p>  friend int Calculate(string s); //計(jì)算每個(gè)單詞的key值</p><p>

36、  friend void getSize(HashTable HT); //獲取當(dāng)前深度和最大深度</p><p>  friend void ASL(HashTable HT);</p><p>  private: </p><p>  int divitor;

37、 //哈希表的除數(shù)</p><p>  int CurrentSize,TableSize; //當(dāng)前深度以及表的容量</p><p>  string ht[DefaultSize]; //哈希表存儲(chǔ)數(shù)組</p><p

38、>  int info[DefaultSize]; //狀態(tài)數(shù)組</p><p>  int FindPos(int key,string value) const; //散列函數(shù):計(jì)算初始的散列地址</p><p><b>  };</b></p><p>  Ha

39、shTable::HashTable(int d, int sz){ //構(gòu)造函數(shù)</p><p>  divitor = d;</p><p>  TableSize = sz; CurrentSize = 0;</p><p>  //ht = new string [TableSize];

40、 //開(kāi)辟散列數(shù)組空間</p><p>  //info = new KindOfStatus[TableSize]; //開(kāi)辟標(biāo)志數(shù)組空間,標(biāo)志是每個(gè)元素的屬性(Active,Empty,Delected)</p><p>  for(int i=0;i<TableSize;i++) {</p><p>  ht[i] = '

41、 '; info[i] = Empty; }</p><p><b>  }</b></p><p>  /**使用線性探測(cè)法搜索 **/</p><p>  int HashTable::FindPos(int key,string value) const{ </p><p>  //搜索一個(gè)散

42、列表中關(guān)鍵碼與key匹配的元素,搜索成功,則函數(shù)返回改元素的位置</p><p>  //否則返回插入點(diǎn)(如果有足夠空間的話)</p><p>  int address= key % divitor;</p><p>  int j = address;</p><p><b>  do{</b></p>

43、<p>  if(info[j]==Empty||info[j]==Deleted||(info[j]==Active&&ht[j]==value)){t1++;return j;} //找到</p><p>  else { j=(j+1) % TableSize; t1++; } //當(dāng)做循環(huán)表處

44、理,找出下一個(gè)空地址</p><p>  }while (j != address); </p><p>  return j; //轉(zhuǎn)一圈回到起點(diǎn),表已滿(mǎn),失敗</p><p>  } //t1在這個(gè)函數(shù)體里面增加的量δt1為

45、某一元素探查的次數(shù)</p><p>  bool HashTable::Search(int key,string value){</p><p>  //使用線性探測(cè)在哈希表ht(每個(gè)地址容納一個(gè)元素)中搜索word。如果word在表中存在,</p><p>  //則函數(shù)返回true,并用引用參數(shù)value返回找到的元素;如果word不在表中,則返回false。

46、</p><p>  int temp=t1;</p><p>  int i = FindPos(key,value);</p><p>  if(value == ht[i]) {cout<<"此單詞在 "<<i<<" 位置";t1=temp;return true;}</p>

47、;<p>  else {t1=temp;return false;}</p><p><b>  }</b></p><p>  int Calculate(string s){</p><p>  //key計(jì)算函數(shù):word前5個(gè)字符的ASCII碼 + 單詞長(zhǎng)度</p><p>  //不足5個(gè)字符的

48、word,用所有字符的ASCII碼 + 單詞長(zhǎng)度</p><p>  int k=0,len; </p><p>  len=s.length();</p><p>  if(len<5){</p><p>  for(unsigned int i=0;i<s.length();i++) k+=(int)s[i]; }</p

49、><p><b>  else{</b></p><p>  for(int i=0;i<=4;i++) k+=(int)s[i]; }</p><p><b>  k+=len;</b></p><p><b>  return k;</b></p><

50、p><b>  }</b></p><p>  int HashTable::Insert(string value){</p><p>  //在ht表中搜索value。若找到則不再插入;若未找到,但表已滿(mǎn),也不再插入,并返回false。</p><p>  //若找到的位置標(biāo)志是Empty或Deleted,不論是表是否已滿(mǎn)都插入,返回

51、true。</p><p>  int key = Calculate(value); //計(jì)算函數(shù):抽取關(guān)鍵碼</p><p>  int i = FindPos(key,value); //地址計(jì)算</p><p>  int flag=0;</p><p

52、><b>  do{</b></p><p>  if(info[i] != Active){ //該地址未被存放,存放新元素</p><p>  ht[i] = value; info[i] = Active;</p><p>  getInfo(i);</p><p&g

53、t;  CurrentSize++; </p><p>  flag = 1; break; }</p><p>  if(info[i] == Active && ht[i] == value)</p><p>  { cout<<"表中已有此元素,不用在插入!"<<endl; flag = -1;t1-

54、-;break;}</p><p>  if(info[i] == Active && ht[i] !=value) i++;</p><p>  }while(i<TableSize);</p><p>  if(i>=TableSize) { cout<<"表已滿(mǎn),不能插入!"<<endl

55、; t1--;}</p><p>  return flag;</p><p><b>  }</b></p><p>  bool HashTable::Remove(int key ,string value){</p><p>  //在ht表中刪除元素word,若表中找不到word,或雖然找到word,但它已經(jīng)邏

56、輯刪除過(guò)</p><p>  //則返回false,否則在表中刪除元素word,返回true,并在引用參數(shù)value中得到它</p><p>  int temp=t1;</p><p>  int i = FindPos(key,value);</p><p>  if(info[i] == Active && ht[i]

57、== value){ //找到要?jiǎng)h元素,且是活動(dòng)元素</p><p>  info[i] = Deleted; CurrentSize--; //做刪除標(biāo)志,并不是真正的物理刪除</p><p>  cout<<"元素已被刪除"<<endl;</p><p>  getInfo(i

58、);</p><p>  t1=t1-2*(t1-temp); //t1-temp為這個(gè)元素的探查次數(shù)(δt1)</p><p>  return true; //刪除成功</p><p><b>  }</b></p&

59、gt;<p>  else { cout<<"找不到這個(gè)元素或者這個(gè)元素已經(jīng)被刪除過(guò)。"<<endl;t1=temp;return false; } //刪除失敗,t1不變</p><p><b>  }</b></p><p>  void HashTable::makeEmpty(){</p>

60、<p>  for(int i=0;i<TableSize;i++) { ht[i] = " ";info[i] = Empty;}</p><p>  CurrentSize = 0;</p><p><b>  t1=0;</b></p><p>  cout<<"散列表已被置空

61、"<<endl;</p><p><b>  }</b></p><p>  void getSize(HashTable HT){</p><p>  if(HT.CurrentSize>=0 && HT.TableSize>=0){</p><p>  cout<

62、;<"CurrentSize: "<<HT.CurrentSize<<endl;</p><p>  cout<<"TableSize: "<<HT.TableSize<<endl;</p><p><b>  }</b></p><p>

63、<b>  }</b></p><p>  void HashTable::getInfo(int a){</p><p>  cout<<"HT["<<a<<"]= "; </p><p>  cout<<" "<<ht[a

64、]<<"\t"; //HT[a]=value</p><p>  if(info[a] == Empty)</p><p>  cout<<"Empty"<<endl;</p><p>  if(info[a] == Active){<

65、;/p><p>  cout<<"Active"<<" ";</p><p>  cout<<"key: "<<Calculate(ht[a])<<endl;}</p><p>  if(info[a] == Deleted)</p>

66、<p>  cout<<"Deleted"<<endl;</p><p><b>  }</b></p><p>  void ASL(HashTable HT){</p><p>  int i=0,j=0;</p><p>  t2=0;

67、 //重置t2</p><p>  do{ i=j; //外層循環(huán)控制數(shù)組的下標(biāo)</p><p><b>  do{</b></p><p>  if(HT.info[i] != Active) {t2

68、++;break;} //沒(méi)有活動(dòng)的元素,表明可以插入,使用了一次查找次數(shù),t+1</p><p>  else {t2++;i++;} } //找不到空地址,t自加</p><p>  while(i<HT.TableSize); j++ ;} //內(nèi)存循環(huán)結(jié)束,j自加,進(jìn)行下一個(gè)元素的計(jì)算<

69、/p><p>  while(j<HT.TableSize); </p><p>  cout<<"ASLsucc:"<<t1<<"/"<<HT.CurrentSize<<"\t";</p

70、><p>  cout<<"ASLunsucc:"<<t2<<"/"<<HT.TableSize<<endl; //最后t的值是所有元素查找不成功次數(shù)的總和</p><p><b>  }</b></p><p> ?、冢鞒绦騢ash_main.

71、cpp</p><p>  #include <string></p><p>  #include "HashTable.h"</p><p>  HashTable HT(29,DefaultSize); // 此處還可以用try...catch語(yǔ)句來(lái)捕捉初始化時(shí)產(chǎn)生的未知錯(cuò)誤</p><

72、p>  string word; // 輸入的單詞</p><p>  void function(){</p><p>  cout<<"接下來(lái)你想要做什么?"<<endl;</p><p>  cout<<"1、查看表 2、搜索 3

73、、插入 4、刪除 5、顯示ASL 6、置空當(dāng)前表 其他:退出"<<endl;</p><p><b>  int c;</b></p><p><b>  cin>>c;</b></p><p>  switch(c){</p><p>  case 1: for

74、(int i=0;i<DefaultSize;i++) HT.getInfo(i);break;</p><p>  case 2: cout<<"請(qǐng)輸入你要查找的單詞:\t"; cin>>word;</p><p>  if(HT.Search(Calculate(word),word)==true)</p><p&g

75、t;  cout<<endl;</p><p>  else cout<<"表中沒(méi)有這個(gè)單詞."<<endl;</p><p><b>  break;</b></p><p>  case 3: cout<<"請(qǐng)輸入您要插入的單詞:\t"; cin>

76、>word;</p><p>  HT.Insert(word); break;</p><p>  case 4: cout<<"請(qǐng)輸入你想要?jiǎng)h除的單詞:\t"; cin>>word;</p><p>  HT.Remove(Calculate(word),word);break; </p><

77、p>  case 5: ASL(HT);break;</p><p>  case 6: HT.makeEmpty();break;</p><p>  default: exit(0); }</p><p><b>  }</b></p><p>  void main()</p><p>

78、;<b>  {</b></p><p>  cout<<"哈希表數(shù)組初始化完畢!"<<endl;</p><p>  int i=0,j=0;</p><p>  for(int i=0;i<DefaultSize;i++) HT.getInfo(i);</p><p>

79、;  getSize(HT);</p><p>  cout<<endl<<"請(qǐng)輸入單詞。"<<endl;</p><p>  cout<<"注意:數(shù)組最大容量為"<<DefaultSize<<endl;</p><p>  cout<<&qu

80、ot;你想輸入幾個(gè)單詞?"<<endl;</p><p>  int count=0; </p><p><b>  do{</b></p><p>  cin>>count;</p><p>  if(count<=0)</p&g

81、t;<p>  cout<<"你的輸入有誤!請(qǐng)?jiān)俅屋斎耄?quot;<<endl;</p><p>  if(count>DefaultSize) </p><p>  cout<<"你輸入的數(shù)超過(guò)了最大容量!請(qǐng)正確輸入:"<<endl;</p>&

82、lt;p><b>  }</b></p><p>  while(count>DefaultSize||count<=0);</p><p>  for(int i=1;i<=count;i++){</p><p>  cout<<"第"<<i<<"個(gè):

83、";</p><p>  cin>>word;</p><p>  if(HT.Insert( word )==-1) i--; //輸入有誤,后退一步再輸入一次</p><p><b>  }</b></p><p>  do{ function();} while(1>0);</

溫馨提示

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

評(píng)論

0/150

提交評(píng)論