- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
问题描述如下:
给定一棵二叉树,检查它是否是自身的镜像(即围绕其中心对称)。
例如,这个二叉树 [1,2,2,3,4,4,3] 是对称的:
1
/ \
2 2
/ \ / \
3 4 4 3
但是下面的 [1,2,2,null,3,null,3] 不是:
1
/ \
2 2
\ \
3 3
来源:Determine if tree is symmetric
我花了很多时间来解决这个问题,我想出的解决方案是进行层次顺序遍历,并检查每个层次中的值是否为回文。这个实现通过了 leetcode 的测试。然而,当我阅读这篇社论时,我看到了一个非常短的递归程序,我一直难以理解它。
public boolean isSymmetric(TreeNode root) {
return isMirror(root, root); }
public boolean isMirror(TreeNode t1, TreeNode t2) {
if (t1 == null && t2 == null) return true;
if (t1 == null || t2 == null) return false;
return (t1.val == t2.val)
&& isMirror(t1.right, t2.left)
&& isMirror(t1.left, t2.right);}
我知道树本身是一种递归数据结构,即由遵循相同结构的左子树和右子树组成,但出于某种原因,当我尝试验证此解决方案的有效性时,我尝试可视化递归调用并最终可视化我的思想纠缠不清。 This guy在解释调用堆栈如何随着递归进行展开方面做得很好,但我只是想改进我对这种“简单”递归问题的思考过程,因此我在这里发帖。
(FWIW,我熟悉递归/DFS/回溯以及调用流程是如何进行的,但我仍然无法提出并验证上述问题的高级递归想法)
感谢您的帮助。
最佳答案
这是可以使用巧妙的递归算法完成的解决方案之一。这个想法是保持两个引用最初指向根,然后将一个子树向左移动,另一个子树向相反的方向移动,并且反转两个 child 的遍历方向,然后指向对称节点任一子树(如果存在)
这里的t1
和t2
指的是左右子树。
if (t1 == null || t2 == null) return false;
这一步的作用是检查是否同时存在右子树和左子树,因为如果我们没有任何一个子树,那么它就不可能是对称的,所以我们返回 false
if (t1 == null && t2 == null) return true;
这说明了可以将 null 作为左子树和右子树的叶节点。所以我们返回真;
return (t1.val == t2.val)
&& isMirror(t1.right, t2.left)
&& isMirror(t1.left, t2.right);}
可以重写为
if(t1.val != t2.val) return false;
auto left = isMirror(t1.right, t2.left)
auto right = isMirror(t1.left, t2.right);
return left && right
现在我们知道两个子树都是有效的(即不为空),然后我们检查它们的值以检查它们是否相同。如果不相同,我们可以返回 false,因为进一步查找没有意义。
我们之所以可以比较是因为我们知道它必须是完全二叉树才能对称我们可以将左子树(t1)移动到左子树(t2)向右移动右子树上的对称节点。
1 (t1, t2)
/ \
2 2
/ \ / \
4 5 5 4
在 isMirror(t1.right, t2.left)
之后
1
/ \
(t2) 2 2(t1)
/ \ / \
4 5 5 4
再次递归调用isMirror(t1.right, t2.left)
后
1
/ \
2 2
/ \ / \
(t2) 4 5 5 4(t1)
现在这将依次调用它的子节点只返回真,因为它们都是空的。然后检查 t1
和 t2
的值并返回 true
或 false
。然后现在调用 isMirror(t1.left, t2.right)
到达这里。
1
/ \
2 2
/ \ / \
4 5 5 4
(t2)(t1)
现在执行与上述步骤相同的操作并展开调用堆栈。
所以在堆栈帧中我们有 left
指示 t1
的左子树是否与 t2
的右子树对称并且 right
表示相反。
因为我们在递归检查它的 child 之前已经检查过 t1.val
是否等于 t2.val
,我们知道根是相等的,如果它的 child 是相等的所以我们返回 return left && right
t1
的子树与 t2
的子树对称
如果这有点令人费解,您可以在纸上追踪它并检查它可能会更好地解决问题。
希望这对您有所帮助。
关于algorithm - 判断二叉树是否对称背后的思考过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46722865/
Transformer 模型是 AI 系统的基础。已经有了数不清的关于 "Transformer 如何工作" 的核心结构图表。 但是这些图表没有提供任何直观的计算该
我有一个很大的索引定义,索引需要很长时间。我怀疑主要问题是由生成的许多 LEFT OUTER JOIN 引起的。 我看到了 this question ,但找不到有关使用 source: :query
我目前是FP的学生。当我查看不同函数式语言提供的不同语法时,我在 Elm 示例代码中遇到了一个模式。我对此很好奇。 这是示例代码 myList = [{foo = "bar1"},{foo = "ba
我正在尝试使用 HTML 和 CSS 进行响应式设计,这是我的问题: 如果你只调整窗口大小,布局适合,如果你只缩放,布局再次适合,我没有问题,但是如果在调整窗口大小时缩放,布局会中断一点。 找到有关此
我正在寻找模型项目。项目属于公司,因此列表中的所有项目都可以附加相同的公司。结果列表示例: CompanyA - ProjectA CompanyA - ProjectO CompanyA - Pro
我使用的编程语言是 Java。我一直在过渡到有些困难的 C++。 “难懂”不在学习中,更多的是“用 C++ 思考”。 我看到很多人说你应该先学习C(我在技术上已经知道了),然后我看到有人说不要跳过C直
我正在整理一个存储库类型的 rails 3 站点。 我安装了 Thinking Sphinx 并在我的网站上工作,因为我可以输入类似 localhost:3000/articles?search=te
我正在使用 sphinx 搜索 2 个模型及其关联。我正在使用增量索引。在开发模式 (Ubuntu) 下,我的开发箱上一切正常。但是,在暂存盒生产环境中,当我创建新记录时,我需要再次构建索引以使新创建
我已将 delta 列添加到我的表中: class AddDeltaIndexToCimgs < ActiveRecord::Migration def change add_column
我安装了think sphinx,运行 rake ts:index 后,无法配置开发文件。文件已创建,但它是空的。 Generating configuration to /Users/lexi87/
这很奇怪。我有 3 个模型(A、B、C)。当 crontab 运行它时,我们工作得很好。 最近,我在为模型 A 索引新条目时遇到问题。 当我手动调用 rake ts:index RAILS_ENV=p
如果我的搜索包含类别(外键)和可选文本,我是否应该使用 Thinking sphinx 来“搜索”未提交搜索字符串(仅提交类别)的地方? 最佳答案 这实际上取决于您的用例。举例来说,假设您有博客文章,
以下代码来自Thinking in C++。作者提到“由于 operator[] 是内联的,您可以使用这种方法来保证不会发生数组边界违规,然后删除传送代码的 require()。”这里指的是内联函数的
这是我确定的: Delta 索引在开发中运行良好 当我推送到生产服务器时,Delta 索引不起作用,并且 searchd.log 中没有记录任何操作 我正在运行 Phusion Passenger,并
最近接了一个项目,性质比较独特,想请教大家一些建议。 我分别使用 asp.net/SQL Server 和 php/mysql。我从来没有把它们混为一谈。但是,我当前的项目要求我在使用 SQL Ser
我目前正忙于学习 Ruby 和 Rails,并且由于我有基于 C 语言的背景,Ruby 的一些概念是新的并且有些陌生。对我来说特别具有挑战性的是适应处理常见问题的“Ruby 方式”,因此我经常发现自己
每次我尝试在 Mac OSX Snow Leopard 上运行带有 Rails 3 的 Sphinx 2.0.1 时,我都会收到以下错误: Failed to start searchd daemon
我正在努力提高我的 TDD/OO 技能,但每次我尝试使用 TDD 来影响设计时,我都会遇到从哪里开始的障碍。 这是我的用例/故事: Identify a subset of clients that
得到这个 HTML: Un Deux Trois mother 在页面中,但是 children,select 和 input 都是动态生成的 试着用类似
我以前使用过 javascript,但现在我开始使用 angularjs,但我对如何做基本的事情感到困惑。 例如:在 JavaScript 中: //here is how i create a c
我是一名优秀的程序员,十分优秀!