路径总和II
2022/6/29 23:23:23
本文主要是介绍路径总和II,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
https://leetcode.cn/problems/path-sum-ii/
/** * Definition for a binary tree node. * type TreeNode struct { * Val int * Left *TreeNode * Right *TreeNode * } */ func pathSum(root *TreeNode, targetSum int) [][]int { stack:=make([]int,0) ways=make([][]int,0) dfs(root,0,targetSum,stack) return ways } var ways [][]int func dfs(now *TreeNode,ans,target int,stack []int){ if now==nil{//递归出口,可能有正数,也可能有负数 return } ans=ans+now.Val stack=append(stack,now.Val) if ans==target&&now.Left==nil&&now.Right==nil{//只有到叶子节点,并且和为target才可以 tmp:=make([]int,len(stack)) copy(tmp,stack) ways=append(ways,tmp) } dfs(now.Left,ans,target,stack) dfs(now.Right,ans,target,stack) ans=ans-now.Val stack=stack[:len(stack)-1] }
这篇关于路径总和II的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-11cursor试用出现:Too many free trial accounts used on this machine 的解决方法
- 2025-01-11百万架构师第十四课:源码分析:Spring 源码分析:深入分析IOC那些鲜为人知的细节|JavaGuide
- 2025-01-11不得不了解的高效AI办公工具API
- 2025-01-102025 蛇年,J 人直播带货内容审核团队必备的办公软件有哪 6 款?
- 2025-01-10高效运营背后的支柱:文档管理优化指南
- 2025-01-10年末压力山大?试试优化你的文档管理
- 2025-01-10跨部门协作中的进度追踪重要性解析
- 2025-01-10总结 JavaScript 中的变体函数调用方式
- 2025-01-10HR团队如何通过数据驱动提升管理效率?6个策略
- 2025-01-10WBS实战指南:如何一步步构建高效项目管理框架?