int dfs(int i,int sum)
{
if(i==n+1) return sum==k;
if(dfs(i+1,sum)) return 1;
if(dfs(i+1,sum+a[i+1])) return 1;
}
这段代码是计算能否从数组 a 中找到任意个数,使其和等于 k 的。难道搜索树从最左边走到底的时候,如果 sum != k 不已经 return 0 了么 ... 为什么程序还能继续跑呢?
return 我理解 ... 就是退到上一个递归的情况,但是为何 return 的是 0 之后依然还能遍历全部搜索树呢?
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.