温馨提示×

c#二叉树如何进行反序列化

c#
小樊
89
2024-07-26 02:39:18
栏目: 编程语言
开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

在C#中,可以使用以下代码来反序列化一个二叉树:

using System;
using System.Collections.Generic;

public class TreeNode
{
    public int val;
    public TreeNode left;
    public TreeNode right;

    public TreeNode(int x)
    {
        val = x;
    }
}

public class BinaryTreeSerializer
{
    public string Serialize(TreeNode root)
    {
        if (root == null)
        {
            return "null";
        }

        return root.val + "," + Serialize(root.left) + "," + Serialize(root.right);
    }

    public TreeNode Deserialize(string data)
    {
        Queue<string> nodes = new Queue<string>(data.Split(','));

        return DeserializeHelper(nodes);
    }

    private TreeNode DeserializeHelper(Queue<string> nodes)
    {
        string val = nodes.Dequeue();

        if (val == "null")
        {
            return null;
        }

        TreeNode node = new TreeNode(int.Parse(val));
        node.left = DeserializeHelper(nodes);
        node.right = DeserializeHelper(nodes);

        return node;
    }
}

public class Program
{
    public static void Main()
    {
        TreeNode root = new TreeNode(1);
        root.left = new TreeNode(2);
        root.right = new TreeNode(3);
        root.left.left = new TreeNode(4);
        root.left.right = new TreeNode(5);

        BinaryTreeSerializer serializer = new BinaryTreeSerializer();
        string serializedData = serializer.Serialize(root);
        Console.WriteLine(serializedData);

        TreeNode deserializedRoot = serializer.Deserialize(serializedData);
        Console.WriteLine(deserializedRoot.val); // Output: 1
    }
}

在上面的代码中,我们定义了一个TreeNode类来表示二叉树的节点,然后定义了一个BinaryTreeSerializer类来实现二叉树的序列化和反序列化功能。Serialize方法用于将二叉树序列化为字符串,Deserialize方法用于将字符串反序列化为二叉树。最后,在Main方法中我们演示了如何使用这两个方法来序列化和反序列化一个二叉树。

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读:php二叉树怎样进行反序列化

0