版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、第3章 鏈表3.4 堆棧(duzhn)的實現(xiàn)說明:請對堆棧這種數(shù)據(jù)結構(sh j ji u)做出評論。用C+語言來實現(xiàn)一個堆棧,你可以選用鏈表或動態(tài)數(shù)組來實現(xiàn)你的堆棧;并請對你的決定做出解釋。你為堆棧設計的程序接口必須完備(wnbi)、規(guī)范、和易于使用。解答:堆棧是一種先入后出、后入先出的數(shù)據(jù)結構。class IntStackstruct Nodeint idata;Node* pnext;public:IntStack ():isize(0),phead(NULL) IntStack ()while(phead!=NULL)Node*p = phead;phead = phead-pnext
2、;delete p;isize = 0;void Push(int i)Node* p = new Node;p-idata = i;p-pnext = phead;phead = p;+isize;bool Pop(int& iout) bool ret = false;if(isize0)iout = phead-idata;Node* p = phead;phead = phead-pnext;delete p;-isize; ret = true;return ret;int Size()return isize;private:int isize;Node* phead;templa
3、teclass Stackstruct NodeType idata;Node* pnext;public:Stack():isize(0),phead(NULL)Stack()while(phead!=NULL)Node*p = phead;phead = phead-pnext;delete p;isize = 0;void Push(Type& i)Node* p = new Node;p-idata = i;p-pnext = phead;phead = p;+isize;bool Pop(Type& tout) bool ret = false;if(isize0)tout = ph
4、ead-idata;Node* p = phead;phead = phead-pnext;delete p;-isize; ret = true; return ret;int Size()return isize;private:int isize;Node* phead;3.5 鏈表的尾指針(zhzhn)說明:有一個單向鏈表,它的元素全都是些整數(shù)。head和tail分別(fnbi)指向該鏈表第一個元素(即頭元素)和最后一個元素(即尾元素)的全局性指針。請實現(xiàn)調用接口如下所示的兩個C語言函數(shù):int Delete(element *elem);int InsertAfter(element
5、 *elem, int data);Delete函數(shù)只有一個輸入?yún)?shù),他就是那個將被刪除的元素。InsertAfter函數(shù)由兩個輸入?yún)?shù),第二個輸入?yún)?shù)給出了新元素的取值,它將被插入到第一個輸入?yún)?shù)所指定的元素的后面。當需要把新元素插入到鏈表的開頭作為新的頭元素時,函數(shù)InsertAfter的第一個輸入?yún)?shù)(即被聲明(shngmng)為element類型的那個輸入?yún)?shù))將被設置為NULL。如果執(zhí)行成功,這兩個函數(shù)將返回“1”;如果不成功,將返回“0”。element *head, *tail;int Delete(element* elem) int ret = 0; if(elem=NULL
6、) return ret; if(elem=head) if(head=tail) head=(tail=NULL); else head = head-next; delete elem; ret = 1; return ret; element* p0=NULL,*p1 = head; while(p1!=NULL) if(p1=elem) break; else p0 = p1; p1 = p1-next; if(p1!=NULL) p0-next = p1-next; delete p1; ret = 1; return ret;element *head,*tail;int Inse
7、rtAfter(element* elem, int data) int ret = 0; element *p = new element; p-data = data; p-next = NULL; if(elem=NULL) if(head=NULL) head = (tail=p); else p-next = head; head = p; ret = 1; return ret; else element* p1=head; while(p1!=NULL) if(p1=elem) break; else p1=p1-next; if(p1!=NULL) p-next = p1-ne
8、xt; p1-next = p; ret = 1; return ret;3.6 對RemoveHead函數(shù)進行(jnxng)糾錯說明(shumng):下面是一個用來刪除單向鏈表的頭元素的函數(shù)。請找出其中的程序漏洞并加以糾正。void RemoveHead(node *head)free(head);head = head-next;解答(jid):void RemoveHead(node *&head)if(head=NULL) return;node* p = head;head = head-next;free(p);3.7 鏈表中的倒數(shù)第m個元素說明:給定一個單向鏈表,請設計一個既節(jié)省
9、時間又節(jié)省空間的算法來找出該鏈表中的倒數(shù)第m個元素。實現(xiàn)這個算法,并為可能出現(xiàn)的特例情況安排好處理措施。“倒數(shù)第m個元素”是這樣規(guī)定的:當m=0時,鏈表的最后一個元素(尾元素)將被返回。解答:node* FindInvM(node* head, int m)if(head=NULL) return NULL;node* pm=head,*p=head;int ipm=0;while(p-next!=NULL)p = p-next;if(ipmnext;if(ipm=m) return pm;else return NULL;3.8 鏈表的扁平化說明:給定一個雙向鏈表。這個雙向鏈表中的每一個元素
10、除固有的后指針和前指針外,還有子指針,每個子指針可能指向也可能不指向另一個雙向鏈表。而那些子雙向鏈表本身(bnshn)還可能有一個或者多個子雙向鏈表,從而形成一種多層次的數(shù)據(jù)結構,如圖所示:對這個鏈表進行扁平化,使全體節(jié)點都出現(xiàn)在一個只有一個層次的雙向鏈表里。已知條件只有原多層次雙向鏈表的第一層次的頭指針(zhzhn)和尾指針。下面是各節(jié)點的+語言(yyn)struct定義:struct nodenode *next;node *prev;node *child;int value; ;void ExpandList(node* pnode)while(pnode!=NULL)if(pnode
11、-child!=NULL)node* p0=pnode-child,*p1=p0;while(p1-next!=NULL) p1 = p1-next;node*pp1 = pnode-next;pnode-next = p0; p1-next = pp1;if(pp1!=NULL) pp1-prev = p1; p0-prev = pnode;pnode = pnode-next;3.9 空鏈表與循環(huán)(xnhun)鏈表bool IsLoopLink(node* head)node* p = head;if(p=NULL) return false;stl:set pset;stl:pairst
12、l:set:iterator, bool pl;pl = pset.insert(p);while(p-next!=NULL)p=p-next;pl = pset.insert(p);if(pl.second=false) return true;return false;第4章 樹和圖4.3 二叉樹:左遍歷(bin l)可使用(shyng)遞歸。4.4 二叉樹:左遍歷(bin l),不使用遞歸使用堆棧緩存子節(jié)點。4.5 二叉樹:最低公共祖先找出根節(jié)點到子節(jié)點的路徑數(shù)組,兩個數(shù)組中最后一個相同的節(jié)點就是最低公共(gnggng)祖先。第5章 數(shù)組與字符串5.3 第一個無重復(chngf)字符(1
13、)以字母(zm)為Key建立hash數(shù)組,第一遍+hash數(shù)組,第二遍找數(shù)組為1的字母,O(2n);(2)從首字母開始,判斷其是否還有相同字母,類似排序,O(n2)5.4 刪除特定字符對remove建立hash數(shù)組,字符為key;遍歷str字符串,如果字符在remove中則不拷貝,否則拷貝前移。效率在O(n+m)。5.5 顛倒單詞的出現(xiàn)順序對字符串進行(jnxng)反向遍歷,找到空格則復制單詞。5.6 整數(shù)(zhngsh)/字符串之間的轉換主要是判斷+-號和計算(j sun)字符串長度,其他好做。第6章 遞歸算法6.1 二分法搜索6.2 字符串的全排列6.3 字符串的全組合(zh)6.4 電話
14、(dinhu)鍵單詞第7章 其他程序設計(chn x sh j)問題7.5 繪制八分之一圓形7.6 矩形是否(sh fu)重疊7.7 字節(jié)(z ji)的升序存儲和降序存儲方式7.8 “1”的個數(shù)7.9 簡單(jindn)的SQL查詢7.10 公司(n s)和員工數(shù)據(jù)庫7.11 最大值,不允許(ynx)使用統(tǒng)計功能7.12 生產(chǎn)者/消費者問題(wnt)第8章 與技術(jsh)、測量、排序有關的智力題8.1 開鎖ANS: take an example of 10, emulate the open and close, and then find the rule.You will find t
15、hat all the opened number is a square number, so the opened number is:1,4,9,16,25,36,49,64,81,100.8.2 三個開關(kigun)ANS: you need to touch the lamp. Firstly open the lamp for 1minute, then closed it, and open the next one. You should go to the room and touch the closed lamp to determine which the first
16、 warm lamp is.8.3 過橋(u qio)ANS: (2+1)(1)(5+10)(2)(2+1)=178.4 找石頭(sh tou)ANS: 3 3 2第9章 與圖形和空間(kngjin)有關的智力題9.1 船和碼頭ANS: 繩子rope9.2 數(shù)方塊ANS: 3*3*3-1*1*1=8ANS: 4*4*4-2*2*2 = 569.3 狐貍(h li)與鴨子ANS: the duck could fly.9.4 導火索ANS: burn wire1 from 2 endpoint and burn wire2 from 1 endpoint meanwhile,When the w
17、ire1 burn out, burn wire2 the other endpoint.It will spend 45 minutes when the wire2 burn out.9.5 躲火車(huch)ANS: 第10章 計算機基礎知識10.3 C+和Java10.4 頭文件10.5 C存儲(cn ch)類別10.6 Friend類10.7 類與結構(jigu)的區(qū)別10.8 父類與子類10.9 參數(shù)傳遞10.10 宏與Inline函數(shù)(hnsh)10.11 繼承(jchng)10.12 面向對象的程序設計(chn x sh j)10.13 與線程有關的程序設計問題10.14 廢棄內(nèi)存的自動回收10.15 32位操作系統(tǒng)(co zu x tn)10.16 網(wǎng)絡(wnglu)性能10.17 高速(o s)磁盤緩存10.18 數(shù)據(jù)庫的優(yōu)點10.19 加密技術10.20 新的加密算法10.21 哈希表與二元搜索樹第11章 非技術問題11.2 你打算從事(cngsh)哪方面的工作?11.3 你最喜歡的程序設計語言(yyn)是哪一種?11.4 你的工作習慣(xgun)是怎樣的
溫馨提示
- 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年國家電網(wǎng)招聘之電工類考試題庫及答案(全國)
- 2024貼瓷磚及藝術地磚定制安裝合同3篇
- 2024版石灰石供應合同模板
- 二零二五年度應急管理及救援裝備租賃合同3篇
- 2025年度人工智能專利池共享與許可合同3篇
- 2025年度城市公共交通設施建設合同規(guī)范3篇
- 二零二四年商業(yè)地產(chǎn)項目新型業(yè)態(tài)招商代理服務合同樣本3篇
- 年度芳香除臭化學品:空氣清新劑產(chǎn)業(yè)分析報告
- 2025年新型材料現(xiàn)貨購銷合同標準范本3篇
- 2024-2025學年高中歷史第二單元古希臘和古羅馬的政治制度單元總結學案含解析岳麓版必修1
- 2025年病案編碼員資格證試題庫(含答案)
- 企業(yè)財務三年戰(zhàn)略規(guī)劃
- 提高膿毒性休克患者1h集束化措施落實率
- 山東省濟南市天橋區(qū)2024-2025學年八年級數(shù)學上學期期中考試試題
- 主播mcn合同模板
- 新疆2024年中考數(shù)學試卷(含答案)
- 2024測繪個人年終工作總結
- DB11 637-2015 房屋結構綜合安全性鑒定標準
- 制造業(yè)生產(chǎn)流程作業(yè)指導書
- DB34∕T 4444-2023 企業(yè)信息化系統(tǒng)上云評估服務規(guī)范
- 福建中閩能源股份有限公司招聘筆試題庫2024
評論
0/150
提交評論