使用 C# lamda 表达式写的两种递归函数

使用 C# lamda 表达式写的两种递归函数

//将一个平行数据,整理为一个树形数据
private void Test1(List<myType> allTypeList)
{
//查找父节点
List<myType> rootType = allTypeList.Where(o => o.ParentId == -1).ToList();
//递归主函数
Action<myType> addChildType = null;
addChildType
= (typeInfo =>
{
var childInfo = allTypeList.Where(o => o.ParentId == typeInfo.id);
if (childInfo.IsNullOrDbNull())
return;
childInfo.All(
o =>
{
typeInfo.ChildTypes.Add(o);
addChildType(o);
return true;
});
});
//递归调用
allTypeList.ForEach(
o =>
{
addChildType(o);
});
}

//递归查找指定节点的完整路径
private void Test2(string id)
{
List<myType> crumbs = new List<myType>();
//递归查询指定 id 的完整路径,arg1=待查询id,arg2=子节点集合,arg3=父节点信息
Func<string, List<myType>, myType> getTypeFullPath = null;
getTypeFullPath
= (
(id, childList) =>
{
foreach (var child in childList)
{
if (childList.IsNullOrDbNull())
return null;

if (child.id.ToString().Equals(id))
{
return child;
}
if (child.ChildTypes.Count > 0)
{
var result = getTypeFullPath(id, child.ChildTypes);
if (!result.IsNullOrDbNull())
{
//result.id 和 result.Name 是 myType 类的属性字段
crumbs.Add(new myType() {Id = result.id, Name = result.Name});
return child;
}
}
}
return null;
});

//递归入口
myType typeinfo = = getTypeFullPath(threeLevelType, productTypeList);
//这里返回的是一级节点
if (!typeinfo.IsNullOrDbNull())
{
crumbs.Add(new myType() { Id = typeinfo.id.ToString(), Name = typeinfo.TypeName });
}

return crumbs;
}

转载保留:http://www.iqingcao.com

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值