Lintcode7 Binary Tree Serialization solution 題解

【題目描述】

Design an algorithm and write code to serialize and deserialize a binary tree. Writing the tree to a file is called 'serialization' and reading back from the file to reconstruct the exact same binary tree is 'deserialization'.

設(shè)計(jì)一個(gè)算法猾普,并編寫代碼來序列化和反序列化二叉樹磷蜀。將樹寫入一個(gè)文件被稱為“序列化”,讀取文件后重建同樣的二叉樹被稱為“反序列化”。

如何反序列化或序列化二叉樹是沒有限制的芜壁,你只需要確保可以將二叉樹序列化為一個(gè)字符串碰缔,并且可以將字符串反序列化為原來的樹結(jié)構(gòu)喇颁。

注意:There is no limit of how you deserialize or serialize a binary tree, LintCode will take your output of serialize as the input of deserialize, it won't check the result of serialize.

【題目鏈接】

http://www.lintcode.com/en/problem/binary-tree-serialization/

【題目解析】

根據(jù)之前由前序,中序初澎,后序遍歷恢復(fù)二叉樹的經(jīng)驗(yàn)秸应,確定根節(jié)點(diǎn)的位置十分重要(但是這里可能有重復(fù)元素虑凛,故和之前的題目不太一樣)。能直接確定根節(jié)點(diǎn)的有前序遍歷和廣度優(yōu)先搜索软啼,其中較為簡(jiǎn)潔的為前序遍歷桑谍。序列化較為簡(jiǎn)單,但是反序列化的實(shí)現(xiàn)不太容易祸挪。需要借助字符串解析工具锣披。

源碼分析:由二叉樹序列化的過程不難,難就難在根據(jù)字符串進(jìn)行反序列化贿条,這里引入了 Java 中的 StringTokenizer 字符串分割工具雹仿,非常方便,使得遞歸得以順利實(shí)現(xiàn)整以。其中deseriaHelper的實(shí)現(xiàn)較為巧妙胧辽。

【答案鏈接】

http://www.jiuzhang.com/solutions/binary-tree-serialization/

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市公黑,隨后出現(xiàn)的幾起案子邑商,更是在濱河造成了極大的恐慌,老刑警劉巖凡蚜,帶你破解...
    沈念sama閱讀 222,627評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件人断,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡番刊,警方通過查閱死者的電腦和手機(jī)含鳞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來芹务,“玉大人蝉绷,你說我怎么就攤上這事≡姹В” “怎么了熔吗?”我有些...
    開封第一講書人閱讀 169,346評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長佳晶。 經(jīng)常有香客問我桅狠,道長,這世上最難降的妖魔是什么轿秧? 我笑而不...
    開封第一講書人閱讀 60,097評(píng)論 1 300
  • 正文 為了忘掉前任中跌,我火速辦了婚禮,結(jié)果婚禮上菇篡,老公的妹妹穿的比我還像新娘漩符。我一直安慰自己,他們只是感情好驱还,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,100評(píng)論 6 398
  • 文/花漫 我一把揭開白布嗜暴。 她就那樣靜靜地躺著凸克,像睡著了一般。 火紅的嫁衣襯著肌膚如雪闷沥。 梳的紋絲不亂的頭發(fā)上萎战,一...
    開封第一講書人閱讀 52,696評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音舆逃,去河邊找鬼蚂维。 笑死,一個(gè)胖子當(dāng)著我的面吹牛路狮,可吹牛的內(nèi)容都是我干的鸟雏。 我是一名探鬼主播,決...
    沈念sama閱讀 41,165評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼览祖,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了炊琉?” 一聲冷哼從身側(cè)響起展蒂,我...
    開封第一講書人閱讀 40,108評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎苔咪,沒想到半個(gè)月后锰悼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,646評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡团赏,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,709評(píng)論 3 342
  • 正文 我和宋清朗相戀三年箕般,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片舔清。...
    茶點(diǎn)故事閱讀 40,861評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡丝里,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出体谒,到底是詐尸還是另有隱情杯聚,我是刑警寧澤,帶...
    沈念sama閱讀 36,527評(píng)論 5 351
  • 正文 年R本政府宣布抒痒,位于F島的核電站幌绍,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏故响。R本人自食惡果不足惜傀广,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,196評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望彩届。 院中可真熱鬧伪冰,春花似錦、人聲如沸惨缆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至寂汇,卻和暖如春病往,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背骄瓣。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評(píng)論 1 274
  • 我被黑心中介騙來泰國打工停巷, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人榕栏。 一個(gè)月前我還...
    沈念sama閱讀 49,287評(píng)論 3 379
  • 正文 我出身青樓畔勤,卻偏偏與公主長得像,于是被迫代替她去往敵國和親扒磁。 傳聞我的和親對(duì)象是個(gè)殘疾皇子庆揪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,860評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容