版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
重慶交通大學設計性實驗報告班級:計軟2班學號:姓名:舊城余約實驗項目名稱:找尋實驗項目性質(zhì):設計性實驗實驗所屬課程:算法與數(shù)據(jù)構造實驗室(中心):B01-407指導教師:魯云平實驗完成時間:2015年5月20日教師評閱建議:簽字:年代日實驗成績:一、實驗目的應用線性構造、樹形構造實現(xiàn)查找。二、實驗內(nèi)容及要求內(nèi)容:)有序表的二分查找;2)二叉排序樹的查找。要求:1)建立有序表,爾后進行二分查找;2)建立二叉排序樹,爾后查找。三、
實驗設備及軟件設備:計算機;軟件:visualC++四、
實驗過程及步驟運行環(huán)境:visualC++;實現(xiàn)思路:第一,是有序表的書寫,是在序次表的基礎上用有序插入控制數(shù)據(jù)的有序輸入,從而建立有序表,為后邊的二分法查找數(shù)據(jù)做準備。序次表的數(shù)據(jù)成員中,用*element來儲藏數(shù)據(jù),MaxSize表示最大儲藏空間,length表示當前儲藏長度;在成員函數(shù)中,voidInsert(T&x)用來有序插入數(shù)據(jù)建立有序表,每次插入數(shù)據(jù)前都要與已有數(shù)據(jù)進行比較大小,從而確定插入地址,同時voidSearch(T&x)用來二分法查找數(shù)據(jù),先定義兩個初步地址和末地址的變量以及一此中間地址的變量,每次用要查找的數(shù)與中間地址的數(shù)據(jù)進行比較,若是小則末地址為中間地址加一,反之初步地址為中間地址減一;爾后,是二分排序樹的書寫,有二叉樹結點BinaryTreeNode,包括數(shù)據(jù)域data,左子樹指針leftChild以及右子樹指針rightChild;在BinarySearchTree中用voidInsert(T&x,BinaryTreeNode<T>*&ptr)函數(shù)進行建立二叉樹,比根數(shù)據(jù)小的存在左子樹,比根大的存在右子樹,用BinaryTreeNode<T>*Find(Tx,BinaryTreeNode<T>*ptr)進行搜索查找,用遞歸算法進行實現(xiàn),要查找的數(shù)比根數(shù)小,往左子樹遞歸,反之,往右子樹遞歸。最后,用菜單進行實現(xiàn)。編譯步驟:在寫類的時候,逐個函數(shù)進行測試。五、主要代碼及運行結果(一)、主要代碼:SeqList類:#include<>template<classT>classSeqList{private:*element;intMaxSize;intlength;public:SeqList(intMaxListSize=10);~SeqList( ){if(element)delete[]element;}boolIsEmpty( ){returnlength==0;}intLength( ){returnlength;}boolFind(inti,T&x);//將第i個元素的值用x返回SeqList<T>Delete(inti,T&x);//刪除第i個元素,并返回voidSearch(T&x);//二分法找尋函數(shù)voidInsert(T&x);//有序插入建立有序表voidOutput( );TGetNumber(inti){returnelement[i];}
x的值};template<classT>SeqList<T>::SeqList(intMaxListSize){MaxSize=MaxListSize;element=newT[MaxSize];length=0;}template<classT>boolSeqList<T>::Find(inti,T&x){if(i<1||i>length)returnfalse;else{x=element[i-1];returntrue;}}template<classT>voidSeqList<T>::Search(T&x){inthigh=length;intlow=0;intmid;while(low<=high){mid=(low+high)/2;if(x>element[mid])low=mid+1;elseif(x<element[mid])high=mid-1;elseif(x==element[mid]){cout<<"查找成功!"<<endl;cout<<mid+1;break;}}if(x!=element[mid]&&(mid==low||mid==high))cout<<"
查找失敗
"<<endl;}template<classT>voidSeqList<T>::Output( ){for(inti=0;i<length;i++)cout<<element[i]<<"";}template<classT>voidSeqList<T>::Insert(T&x)//{
有序插入函數(shù)inti=0;while(i<length&&element[i]<=x)//
比較i++;for(intj=length;j>i;j--)//
有序插入element[j]=element[j-1];element[i]=x;length++;}BinarySearchTree類:#include<iostream>usingnamespacestd;template<classT>classBinarySearchTree;template<classT>classBinaryTreeNode{protected:Tdata;BinaryTreeNode<T>*leftChild,*rightChild;public://BinaryTreeNode( ):leftChild(NULL),rightChild(NULL){}////BinaryTreeNode(Td):data(d),leftChild(NULL),rightChild(NULL){}//BinaryTreeNode(Td=0,BinaryTreeNode*L=NULL,BinaryTreeNode*R=NULL):data(d),leftChild(L),rightChild(R){}//構造函數(shù)~BinaryTreeNode( ){
構造函數(shù)
構造函數(shù)if(leftChild)deleteleftChild;if(rightChild)deleterightChild;}TGetData( ){returndata;}friendclassBinarySearchTree<T>;};template<classT>classBinarySearchTree{private:BinaryTreeNode<T>*root;//
二叉找尋樹的根指針Tstopvalue;//數(shù)據(jù)輸入停止標志,用于輸入voidInsert(T&x,BinaryTreeNode<T>*&ptr);//插入BinaryTreeNode<T>*Find(Tx,BinaryTreeNode<T>*ptr);//voidTraverse(ostream&out,BinaryTreeNode<T>*subTree);//public:BinarySearchTree( ):root(NULL){}//構造函數(shù)BinarySearchTree(Tvalue):stopvalue(value),root(NULL){}//~BinarySearchTree( )
查找前序遍歷輸出構造函數(shù){if(root)deleteroot;}//析構函數(shù)intFind(Tx){returnFind(x,root)!=NULL;}//查找voidInsert(T&x){Insert(x,root);}//插入新元素voidTraverse(ostream&out){Traverse(out,root);}};template<classT>BinaryTreeNode<T>*BinarySearchTree<T>::Find(Tx,BinaryTreeNode<T>*ptr)//
二叉排序樹的遞歸查找算法{if(ptr==NULL){cout<<"找尋失??!"<<endl;returnNULL;//找尋失敗}elseif(x<ptr->data)returnFind(x,ptr->leftChild);//
在左子數(shù)查找elseif(x>ptr->data)returnFind(x,ptr->rightChild);//
在右子數(shù)查找else{cout<<"找尋成功!"<<endl;returnptr;//相等,找尋成功}}template<classT>voidBinarySearchTree<T>::Insert(T&x,BinaryTreeNode<T>*&ptr){if(ptr==NULL)//新節(jié)點作為葉子結點插入{ptr=newBinaryTreeNode<T>(x);//創(chuàng)辦新節(jié)點if(ptr==NULL){cout<<"內(nèi)存不足!"<<endl;exit(1);}}elseif(x<ptr->data)Insert(x,ptr->leftChild);//小于等于根的要點字,向左子樹插入我不清楚和根相等的要點字往哪里存elseif(x>ptr->data)Insert(x,ptr->rightChild);//大于根的要點字,向右子數(shù)插入}/*template<classT>voidBinarySearchTree<T>::Remove(constT&x,BinaryTreeNode<T>*&ptr){BinaryTreeNode<T>*temp;if(ptr!=NULL)if(x<ptr->data)Remove(x,ptr->leftChild);elseif(x>ptr->data)Remove(x,ptr->rightChild);elseif(ptr->leftChild!=NULL&&ptr->rightChild!=NULL){temp=Min(ptr->rightChild);ptr->data=temp->data;Remove(ptr->data,ptr->rightChild);}else{temp=ptr;if(ptr->leftChild==NULL)ptr=ptr->rightChild;elseif(ptr->leftChild==NULL)ptr=ptr->leftChild;deletetemp;}}*/template<classT>voidBinarySearchTree<T>::Traverse(ostream&out,BinaryTreeNode<T>*subTree)//
私有函數(shù):找尋并輸出根為
subTree
的二叉樹{if(subTree!=NULL){out<<subTree->data<<'';//輸出Traverse(out,subTree->leftChild);//Traverse(out,subTree->rightChild);//
subTree的數(shù)值遞歸找尋并輸出subTree的左子樹遞歸并輸出subTree的右子樹}}/*template<classT>ostream&operator<<(ostream&out,BinarySearchTree<T>&Tree){,out);out<<endl;returnout;}*/出!~~~~~~~~~\n";Menu類:#include""#include""template<classT>classMenu{public:voidBillsOfSearch(SeqList<T>&ob1,BinarySearchTree<T>&ob2);voidInputNumber(SeqList<T>&ob1,BinarySearchTree<T>&ob2);voidOutputNumber(SeqList<T>&ob1,BinarySearchTree<T>&ob2);voidSearchNumber(SeqList<T>&ob1,BinarySearchTree<T>&ob2);};template<classT>voidMenu<T>::BillsOfSearch(SeqList<T>&ob1,BinarySearchTree<T>&ob2){intchoice;while(choice){cout<<endl;cout<<"\n=============================\n";cout<<"|找尋選項|\n";cout<<"=============================\n";cout<<"~~~~~~~1、輸入數(shù)據(jù)!~~~~~~~~~\n";cout<<"~~~~~~~2、輸出數(shù)據(jù)!~~~~~~~~~\n";cout<<"~~~~~~~3、找尋數(shù)據(jù)!~~~~~~~~~\n";cout<<"~~~~~~~0、退cout<<"請輸入你的選擇(輸入編號即可):";cin>>choice;switch(choice){case1:InputNumber(ob1,ob2);break;case2:OutputNumber(ob1,ob2);break;case3:SearchNumber(ob1,ob2);break;case0:break;default:cout<<"輸入有誤!";break;}}}template<classT>voidMenu<T>::InputNumber(SeqList<T>&ob1,BinarySearchTree<T>&ob2){Tnumber;intsign=1,i=0;while(sign)//循環(huán)建立有序表{i++;cout<<"請輸入第"<<i<<"個數(shù)據(jù):(輸入0停止)";cin>>number;if(number==0){intchoose=1;while(choose){cout<<"0可否為要輸入的數(shù)?(1、是;0、不是。)";cin>>choose;switch(choose){case1:(number);(number);choose=0;break;case0:sign=0;break;default:cout<<"輸入選擇有誤,請重新選擇!"<<endl;break;}/*if(choose==1){(number);//建立有序表(number);//建立二叉找尋樹choose=0;}elseif(choose==0)sign=0;elsecout<<"輸入選擇有誤,請重新選擇!"<<endl;*/}}else{(number);//建立有序表(number);//建立二叉找尋樹}}/*for(intj=0;j<( );j++){number1=(j);(number1);//將建立的序次表變換為二叉找尋樹}*/}template<classT>voidMenu<T>::OutputNumber(SeqList<T>&ob1,BinarySearchTree<T>&ob2){intchoose;while(choose){cout<<endl;cout<<"\n=============================\n";cout<<"|輸出選項|\n";cout<<"=============================\n";cout<<"|~~~~~~1、序次表輸出!~~~~~~~|\n";cout<<"|~~~~~~2、二叉找尋樹輸出!~~~|\n";cout<<"|~~~~~~0、退出!~~~~~~~~~~|\n";cout<<"請輸入你的選擇:";cin>>choose;switch(choose){case1:( );break;case2:(cout);break;case0:break;default:cout<<"輸入有誤!";break;}}/*if(choose==1)( );elseif(choose==2)(cout);elsecout<<"輸入有誤!"<<endl;*/}template<classT>voidMenu<T>::SearchNumber(SeqList<T>&ob1,BinarySearchTree<T>&ob2){intchoose;Tx;cout<<"請輸入你要查找的數(shù):";cin>>x;while(choose){cout<<endl;cout<<"\n===================================\n
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年中國壓縮餐巾市場調(diào)查研究報告
- 2024年中國上滑市場調(diào)查研究報告
- 2024年中國P型存水彎帶檢查口市場調(diào)查研究報告
- 2024年中國14500噸化學品船市場調(diào)查研究報告
- 2025至2030年中國鮮葡萄果凍行業(yè)投資前景及策略咨詢研究報告
- 2025至2030年中國電子冰箱行業(yè)投資前景及策略咨詢研究報告
- 2025至2030年中國棉紡鏈行業(yè)投資前景及策略咨詢研究報告
- 2025至2030年中國臥式雙軸榫行業(yè)投資前景及策略咨詢研究報告
- 2025至2030年中國不銹鋼水果刀行業(yè)投資前景及策略咨詢研究報告
- 2024年中國鍋/杯墊市場調(diào)查研究報告
- 供應鏈管理規(guī)章制度
- 高中語文課后作業(yè)設計
- 2024年新蘇教版科學六年級上冊全冊知識點(超全)
- 2023非預應力鋼筒混凝土管
- 四川省成都東部新區(qū)2023-2024學年七年級上學期期末語文試題(原卷版)
- 中國特色社會主義思想讀本小學低年級第1講第1課時《美麗中國是我家》教學設計
- 2024年3月八省八校T8第二次聯(lián)考語文試題及答案
- 三單形式三年級英語練習題
- 程序設計基礎-C智慧樹知到期末考試答案章節(jié)答案2024年四川師范大學
- NBT-10779-2021空氣源熱泵集中供暖工程設計規(guī)范
- 廣東省深圳市羅湖區(qū)2023-2024學年二年級下學期期末考試數(shù)學試題
評論
0/150
提交評論