ツリーのシーケンス化と逆シーケンス化
1780 ワード
タイトルの説明
2つの関数を実装してください.それぞれシリアル化と逆シーケンス化のツリーに使用します.
インプリメンテーション
public class Solution {
String Serialize(TreeNode root) {
StringBuffer sb=new StringBuffer();
if(root==null){
sb.append("#,");
return sb.toString();
}
sb.append(root.val+",");
sb.append(Serialize(root.left));
sb.append(Serialize(root.right));
return sb.toString();
}
int index=-1;
TreeNode Deserialize(String str){
index++;
String[] s=str.split(",");
TreeNode root=null;
if(!s[index].equals("#")){
root=new TreeNode(Integer.parseInt(s[index]));
root.left=Deserialize(str);
root.right=Deserialize(str);
}
return root;
}
}