欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 健康 > 养生 > 二叉树从根节点出发的所有路径

二叉树从根节点出发的所有路径

2024/11/30 12:45:59 来源:https://blog.csdn.net/LIQIANGEASTSUN/article/details/140072270  浏览:    关键词:二叉树从根节点出发的所有路径

二叉树从根节点出发的所有路径

在这里插入图片描述
看上图中 二叉树结构
从根节点出发的所有路径 如下
6->4->2->1
6->4->2->3
6->4->5
6->8->7
6->8->9

逻辑思路:
按照先序遍历 加 回溯法 实现

代码如下

        // 调用此方法,将根节点传递进来public static IList<IList<int>> Path(BinNode<int> root){// 存储所有路径,每一项为一个路径List<IList<int>> resultList = new List<IList<int>>();List<int> list = new List<int>();Path(root, resultList, list);// 遍历打印所有路径foreach(var listTemp in resultList){string msg = "";foreach(var item in listTemp){msg += "->" + item;}Console.WriteLine(msg);}return resultList;}public static void Path(BinNode<int> root, IList<IList<int>> resultList, List<int> list){if (null == root){return;}list.Add(root.Element);// 如果 左子树和右子树 都不存在,则路径结束if (null == root.LeftChild && null == root.RightChild){List<int> newList = new List<int>(list);// 将路径存储resultList.Add(newList);return;}if (root.LeftChild != null){Path(root.LeftChild, resultList, list);// 回溯list.RemoveAt(list.Count - 1);}if (root.RightChild != null){Path(root.RightChild, resultList, list);// 回溯list.RemoveAt(list.Count - 1);}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com