使用 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;
}