EE_DSnP 板


LINE

Please go to homework website to download. Some comments: 1. 最後還是決定不要用 _tail (dummy node) 了, 因為好像沒什麼必要, 但卻會引起一個不太好處理的 bug... 2. 沒有 _parent, 原因是覺得 maintain 他太麻煩 3. 因為沒有 _parent, 所以當一個 node 的 right = 0 時, successor() 並不好找... 所以 keep 了一個 _trace 在 iterator 裡, 記錄這個 iterator 走過的痕跡... 不過跟我上課時說的不同, 我不是用 static data member, 因為這樣無法支援 多個 iterator 同時存在, 而且 li++ 及 li-- 也沒有辦法同時使用. 至於我的 trace 怎麼做... 其實還蠻簡單的, 應該是少於 50 行 code, 所以我賣個關子... XD 4. 建議大家先將 insert() and erase() 做好後先測一下, 不過為了讓 adtPrint 可以動作, 我寫了一個 BSTree::print() 如下: void BSTree::print() const { if (_root) _root->print(0); } void BSTreeNode::printSpace(size_t indent) const { for (size_t i = 0; i < indent; ++i) cout << ' '; } void BSTreeNode::print(size_t indent) const { printSpace(indent); cout << _data << endl; if (_left) _left->print(indent+2); else { printSpace(indent+2); cout << "[0]" << endl; } if (_right) _right->print(indent+2); else { printSpace(indent+2); cout << "[0]" << endl; } } 然後在 adtTest.h 裡加上: void print(bool reverse = false) { #ifdef TEST_BST _container.print(); #endif ... 目前所附的 reference program 我並沒有將這個 print() 拿掉, 可以給大家參考一下. 5. ADTDelete -Random 會很慢, 主要是因為 AdtTest::getPos(). 稍微改善了一下: AdtType<AdtTestObj>::iterator li = _container.begin(); AdtType<AdtTestObj>::iterator lj = _container.end(); while ((li != lj) && (i++ != pos)) ++li; 不過還是有點慢就是了. --



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 59.121.129.110
1F:推 bnsblue:要是我已經用了_parent寫.......orz 05/16 08:39
2F:推 timrau:STL set的node也是有parent的 所以也還好XD 05/16 10:29
3F:推 bnsblue:真的喔 XD 我本來想去看set的 我記得那好像也是BST架構 05/16 12:09
4F:→ bnsblue:可是後來想這樣就作弊了XD就算了 05/16 12:09
5F:推 danielko:好像還是得iterator寫完再測 不然adtTest.h 05/16 14:32
6F:→ danielko:compile會不給過 orz 05/16 14:32
7F:推 bnsblue:你有把上面幾個print放到該放的地方嗎@@ 05/16 15:00
8F:推 danielko:所以要放到bst.h還是adtTest.h ?? 05/16 17:18
9F:→ danielko:喔喔 我看到老師新po的文章了 XD 05/16 17:18
10F:→ ric2k1:大家交上來的時候不要把上面的 print 加進去哦! 05/17 09:43







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:WOW站內搜尋

TOP