首页 > 其他 > 详细

计算目录树的深度-基于linq

时间:2014-10-11 02:12:45      阅读:268      评论:0      收藏:0      [点我收藏+]

生成word时,有时用户要求要生成所有级别的目录。

这个时候就需要计算目录树的深度。关于求树的深度,已有很多现成的算法。本文主要介绍一种linq的写法。代码看起来挺简洁的。

public static int MenuDepth(List<Menu> menuList, int parentId)
{
    var children = menuList.Where(p => p.parentId == parentId);
    if (children.Count() == 0)
        return 1;
    return 1 + children.Select(p => MenuDepth(menuList, p.id)).Max();
}

 

------------

DavidCai 2014-10-11 于家中

欢迎加我qq讨论任何关于导出word的问题:371323761

计算目录树的深度-基于linq

原文:http://www.cnblogs.com/codestore/p/4018168.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!