序列化二叉樹的一種方法是使用前序遍歷。當我們遇到乙個非空節點時,我們可以記錄下這個節點的值。如果它是乙個空節點,我們可以使用乙個標記值記錄,例如#
。
_9_例如,上面的二叉樹可以被序列化為字串/ \
3 2
/ \ / \
4 1 # 6
/ \ / \ / \
# # # # # #
"9,3,4,#,#,1,#,#,2,#,6,#,#"
,其中#
代表乙個空節點。
給定一串以逗號分隔的序列,驗證它是否是正確的二叉樹的前序序列化。編寫乙個在不重構樹的條件下的可行演算法。
每個以逗號分隔的字元或為乙個整數或為乙個表示null
指標的'#'
。
你可以認為輸入格式總是有效的,例如它永遠不會包含兩個連續的逗號,比如"1,,3"
。
示例 1:
輸入:"9,3,4,#,#,1,#,#,2,#,6,#,#"輸出:true示例 2:
輸入:"1,#"輸出:false示例 3:
輸入:"9,#,#,1"輸出:falseclass solution else ++cnt;
}return cnt == 0 && v.back() == "#";}};
331 驗證二叉樹的前序序列化
序列化二叉樹的一種方法是使用前序遍歷。當我們遇到乙個非空節點時,我們可以記錄下這個節點的值。如果它是乙個空節點,我們可以使用乙個標記值記錄,例如 9 3 2 4 1 6 例如,上面的二叉樹可以被序列化為字串 9,3,4,1,2,6,其中 代表乙個空節點。給定一串以逗號分隔的序列,驗證它是否是正確的二...
331 驗證二叉樹的前序序列化
序列化二叉樹的一種方法是使用前序遍歷。當我們遇到乙個非空節點時,我們可以記錄下這個節點的值。如果它是乙個空節點,我們可以使用乙個標記值記錄,例如 例如,上面的二叉樹可以被序列化為字串 9,3,4,1,2,6,其中 代表乙個空節點。給定一串以逗號分隔的序列,驗證它是否是正確的二叉樹的前序序列化。編寫乙...
331 驗證二叉樹的前序序列化
題目 題目分析 首先,前序遍歷的特點是,以題目示例為例 假設我們從根節點9出發,前序遍歷的第乙個節點是3,這時候,所有的操作都是基於3來執行的,除非3被更深的節點 4或1 覆蓋 就如同3覆蓋根節點9一般 或者3前序遍歷結束,回到了根節點9.這麼一分析,這似乎就是棧結構嘛 假設我們將每個節點都設定乙個...