バイナリの提供-37シーケンスを受賞

バイナリの提供-37シーケンスを受賞

トピック:

アイデア:

自身の答え:
このエラー

public class Solution {
    String Serialize(TreeNode root) {
        if(root == null) return "#!";
        StringBuilder bd = new StringBuilder();
        serializeCore(root, bd);
        return bd.toString();
  }
    private void serializeCore(TreeNode root, StringBuilder bd){
        if(root == null){
            bd.append("#!");
            return;
        }
        bd.append(root.val);
        bd.append("!");
        serializeCore(root.left, bd);
        serializeCore(root.right, bd);
    }
    
    TreeNode Deserialize(String str) {
       if(str == null || str.length() <= 1) return null;
        TreeNode res = null;
        deserializeCore(res, str, 0);
        return res;
  }
    private int end;
    private void deserializeCore(TreeNode res, String str, int start){
        end = str.indexOf("!", start);
        if(end == -1) return;
        String num = str.substring(start, end);
        if(num.equals("#")) return;
        res = new TreeNode(Integer.parseInt(num));
        res.left = null;
        res.right = null;
        deserializeCore(res.left, str, ++end);
        deserializeCore(res.right, str, ++end);
    }
}

間違い:
正しい、デシリアライゼーションは、各ノードをリンクしません

注意:

  1. 参照型を割り当てる場合はnullを、内部をどのように変化するかに関係なく、外またはnullであります
  2. ダウンから、このようなリンクの場合は、次のコードのように、あなたはに同じリターンリンクバックを使用することができます
  3. 文字列、StringBufferの、3種類の間のStringBuilder https://www.cnblogs.com/weibanggang/p/9455926.html

答えに誰か:

/*
public class TreeNode {
    int val = 0;
    TreeNode left = null;
    TreeNode right = null;

    public TreeNode(int val) {
        this.val = val;

    }

}
*/
public class Solution {
    public int index = -1;
    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();
  }
    TreeNode Deserialize(String str) {
        index++;
       int len = str.length();
        if(index >= len){
            return null;
        }
        String[] strr = str.split(",");
        TreeNode node = null;
        if(!strr[index].equals("#")){
            node = new TreeNode(Integer.valueOf(strr[index]));
            node.left = Deserialize(str);
            node.right = Deserialize(str);
        }
         
        return node;
  }
}

おすすめ

転載: www.cnblogs.com/muche-moqi/p/12393042.html