ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

C# 将List转成树的两种方式(递归、循环)

2020-06-17 09:56:51  阅读:289  来源: 互联网

标签:TreeNode 递归 C# List list Add new public


背景

将一个具有ChildCode(子节点)和ParentCode(父节点)的list集合转换成树状结构。

生成数据基本格式,如下图:

 最终展示样式,如下图:

(注:如果你对样式没要求,可以使用layui的树形组件,简单方便-https://www.layui.com/demo/tree.html

  有两种转换方式,一种是普通的递归,一种是双层循环。数据量非很大的情况下,递归的效率相比双层循环来说,效率高一些。
  注:不要循环调用数据库,最好将数据根据条件全部查询出来,然后进行处理。

准备工作

声明一个Model类:

   public class TreeNode
    {
        /// <summary>
        /// 子id
        /// </summary>
        public string Id { get; set; }

        /// <summary>
        /// 父id
        /// </summary>
        public string ParentId { get; set; }

        /// <summary>
        /// 名称
        /// </summary>
        public string Name { get; set; }

        /// <summary>
        /// 子节点
        /// </summary>
        public List<TreeNode> Children { get; set; }

        /// <summary>
        /// 无参构造函数
        /// </summary>
        public TreeNode()
        {
            Children = new List<TreeNode>();
        }

        /// <summary>
        /// 有参构造函数
        /// </summary>
        /// <param name="id">子id</param>
        /// <param name="name">名称</param>
        /// <param name="parentId">父id</param>
        public TreeNode(string id, string name, string parentId)
        {
            this.Id = id;
            this.Name = name;
            this.ParentId = parentId;
            Children = new List<TreeNode>();
        }

        /// <summary>
        /// 有参构造函数
        /// </summary>
        /// <param name="id">子id</param>
        /// <param name="name">名称</param>
        /// <param name="parent">父节点</param>
        public TreeNode(string id, string name, TreeNode parent)
        {
            this.Id = id;
            this.Name = name;
            this.ParentId = parent.Id;
            Children = new List<TreeNode>();
        }
    }

生成一个转换前的list集合:

       TreeNode treeNode1 = new TreeNode("1", "山东", "0");
            TreeNode treeNode2 = new TreeNode("2", "北京", "0");

            TreeNode treeNode3 = new TreeNode("3", "历下区", treeNode1);
            TreeNode treeNode4 = new TreeNode("4", "高新区", treeNode1);
            TreeNode treeNode5 = new TreeNode("5", "历城区", treeNode1);
            TreeNode treeNode6 = new TreeNode("6", "甸柳庄", treeNode3);
            TreeNode treeNode7 = new TreeNode("7", "济南长途汽车站东站", treeNode6);


            TreeNode treeNode8 = new TreeNode("8", "朝阳区", treeNode2);
            TreeNode treeNode9 = new TreeNode("9", "海淀区", treeNode2);
            TreeNode treeNode10 = new TreeNode("10", "金盏乡", treeNode8);


            List<TreeNode> list = new List<TreeNode>();

            list.Add(treeNode1);
            list.Add(treeNode2);
            list.Add(treeNode3);
            list.Add(treeNode4);
            list.Add(treeNode5);
            list.Add(treeNode6);
            list.Add(treeNode7);
            list.Add(treeNode8);
            list.Add(treeNode9);
            list.Add(treeNode10);

递归方式

调用方式:

List<TreeNode> trees1 = TreeHelper.BulidTreeByRecursive(list, new List<TreeNode>(), "0");

实现代码:

/// <summary>
/// 使用递归方法建树
/// </summary>
public static List<TreeNode> BulidTreeByRecursive(List<TreeNode> treeNodes, List<TreeNode> resps, string pID)
{
    resps = new List<TreeNode>();
    List<TreeNode> tempList = treeNodes.Where(c => c.ParentId == pID).ToList();
            
    for (int i = 0; i < tempList.Count; i++)
    {
        TreeNode node = new TreeNode();
        node.Id = tempList[i].Id;
        node.ParentId = tempList[i].ParentId;
        node.Name = tempList[i].Name;
        node.Children = BulidTreeByRecursive(treeNodes, resps, node.Id);
        resps.Add(node);
    }

   return resps;
}

 

双层循环

调用方式:

List<TreeNode> trees = TreeHelper.BulidTree(list);

实现代码:

        /// <summary>
        /// 双层循环
        /// </summary>
        /// <param name="treeNodes"></param>
        /// <returns></returns>
        public static List<TreeNode> BulidTree(List<TreeNode> treeNodes)
        {
            try
            {
                List<TreeNode> trees = new List<TreeNode>();

                foreach (var treeNode in treeNodes)
                {
                    if ("0" == (treeNode.ParentId))
                    {
                        trees.Add(treeNode);
                    }

                    foreach (var it in treeNodes)
                    {
                        if (it.ParentId == treeNode.Id)
                        {
                            treeNode.Children.Add(it);
                        }
                    }
                }
                return trees;
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }    

 

 

有什么不明白的可随时评论,我看到就会回复哦~

对你若有用,“好文要顶”NA~

 

标签:TreeNode,递归,C#,List,list,Add,new,public
来源: https://www.cnblogs.com/pukua/p/13150689.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有