C# 一次循环获取树的两种方法

简介: C# 一次循环获取树的两种方法

第一种方法好些


第二种方法如果中间断开就会成为一级


 private static List<Menu> MenuTree()
        {
            var menu1 = new Menu { Id = 1, ParentId = 0, Name = "aaa" };
            var menu2 = new Menu { Id = 2, ParentId = 0, Name = "bbb" };
            var menu3 = new Menu { Id = 3, ParentId = 0, Name = "ccc" };
            var menu4 = new Menu { Id = 4, ParentId = 1, Name = "ddd" };
            var menu5 = new Menu { Id = 5, ParentId = 2, Name = "eee" };
            var menu6 = new Menu { Id = 6, ParentId = 4, Name = "fff" };
            var menu7 = new Menu { Id = 7, ParentId = 5, Name = "ggg" };
            var menu8 = new Menu { Id = 8, ParentId = 6, Name = "hhh" };
            var menuAll = new List<Menu> { menu1, menu2, menu3, menu4, menu5, menu6, menu7, menu8 };
            var menuList = new List<Menu> { menu1, menu2, menu3, menu4, menu5, menu7, menu8 };
          //第一种方法
            while (true)
            {
                var idList = menuList.Select(x => x.Id).ToList();
                idList.AddRange(menuList.Select(x => x.ParentId).ToList());
                idList = idList.Distinct().ToList();
                var menus = menuAll.Where(x => idList.Contains(x.Id)).ToList();
                if (menus.Count != menuList.Count)
                {
                    menuList = menus;
                    continue;
                }
                break;
            }
       //第二种方法 
            var ret = new List<Menu>();
            foreach (var menu in menuList)
            {
                var model = menuList.FirstOrDefault(x => x.Id == menu.ParentId);
                if (model == null)
                {
                    ret.Add(menu);
                    continue;
                }
                model.Children.Add(menu);
            }
            return ret;
        }

 

相关文章
|
2月前
|
安全 编译器 程序员
C# 中 foreach 循环和 for 循环深度比较
为什么建议你多数情况下使用 foreach 进行遍历循环?看完你就明白了
|
4月前
|
开发框架 .NET 程序员
C# 去掉字符串最后一个字符的 4 种方法
在实际业务中,我们经常会遇到在循环中拼接字符串的场景,循环结束之后拼接得到的字符串的最后一个字符往往需要去掉,看看 C# 提供了哪4种方法可以高效去掉字符串的最后一个字符
407 0
|
3月前
|
编译器 C#
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
134 65
|
2月前
|
JSON 程序员 C#
使用 C# 比较两个对象是否相等的7个方法总结
比较对象是编程中的一项基本技能,在实际业务中经常碰到,比如在ERP系统中,企业的信息非常重要,每一次更新,都需要比较记录更新前后企业的信息,直接比较通常只能告诉我们它们是否指向同一个内存地址,那我们应该怎么办呢?分享 7 个方法给你!
|
2月前
|
C# UED SEO
C# 异步方法async / await任务超时处理
通过使用 `Task.WhenAny`和 `Task.Delay`方法,您可以在C#中有效地实现异步任务的超时处理机制。这种方法允许您在指定时间内等待任务完成,并在任务超时时采取适当的措施,如抛出异常或执行备用操作。希望本文提供的详细解释和代码示例能帮助您在实际项目中更好地处理异步任务超时问题,提升应用程序的可靠性和用户体验。
84 3
|
3月前
|
Java C#
如何避免在C#循环中使用await
如何避免在C#循环中使用await
147 9
|
3月前
|
存储 C#
【C#】大批量判断文件是否存在的两种方法效率对比
【C#】大批量判断文件是否存在的两种方法效率对比
54 1
|
3月前
|
C#
C#的方法的参数传递
C#的方法的参数传递
34 0
|
3月前
|
数据可视化 程序员 C#
C#中windows应用窗体程序的输入输出方法实例
C#中windows应用窗体程序的输入输出方法实例
62 0
|
4月前
|
C#
C#一分钟浅谈:Lambda 表达式和匿名方法
本文详细介绍了C#编程中的Lambda表达式与匿名方法,两者均可用于定义无名函数,使代码更简洁易维护。文章通过基础概念讲解和示例对比,展示了各自语法特点,如Lambda表达式的`(parameters) =&gt; expression`形式及匿名方法的`delegate(parameters)`结构。并通过实例演示了两者的应用差异,强调了在使用Lambda时应注意闭包问题及其解决策略,推荐优先使用Lambda表达式以增强代码可读性。
56 8