查看: 534|回复: 6
收起左侧

[树/链表/图] 226. Invert Binary Tree 这道题为什么必须把root.left, root.right写到一行????

|只看干货
ATPtennis | 显示全部楼层 |阅读模式
本楼: 👍   100% (1)
 
 
0% (0)   👎
全局: 👍   93% (28)
 
 
6% (2)    👎

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
为什么必须要写成
root.left, root.right = self.invertTree(root.right), self.invertTree(root.left)

为什么这样分着写就报错呢?
root.left = self.invertTree(root.right)
root.right = self.invertTree(root.left)

评分

参与人数 1大米 +2 收起 理由
14417335 + 2

查看全部评分


上一篇:热门编程技术网站Educative.io,一亩三分地再献独家折扣!
下一篇:做题做的很沮丧
cloudero 2021-9-23 02:39:08 来自APP | 显示全部楼层
本楼: 👍   100% (1)
 
 
0% (0)   👎
全局: 👍   100% (41)
 
 
0% (0)    👎
分着写的话第二行运行的时候root.left已经被第一行变了。
回复

使用道具 举报

 楼主| ATPtennis 2021-9-23 04:21:54 | 显示全部楼层
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   93% (28)
 
 
6% (2)    👎
cloudero 发表于 2021-9-22 20:39
分着写的话第二行运行的时候root.left已经被第一行变了。

一语中的,明白了,谢谢!
PYTHON写到一行的意思是同时运行两个变量吗?不分先后是这样吗?
回复

使用道具 举报

本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   94% (2583)
 
 
5% (152)    👎
ATPtennis 发表于 2021-09-22 13:21:54
一语中的,明白了,谢谢!
PYTHON写到一行的意思是同时运行两个变量吗?不分先后是这样吗?
相当于swap
回复

使用道具 举报

cloudero 2021-9-23 09:00:51 | 显示全部楼层
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   100% (41)
 
 
0% (0)    👎
ATPtennis 发表于 2021-9-22 16:21
一语中的,明白了,谢谢!
PYTHON写到一行的意思是同时运行两个变量吗?不分先后是这样吗?

我猜测你的意思是 因为写到了一行,所以self.invertTree(root.right)和self.intertTree(root.left)不分先后同时运行。如果你是这么理解的话,那不对。如果不是这样请忽略。运行总是有先后的,这里的区别是,一行的时候当你在运行 self.invertTree(root.left)的这个root.left还是曾经的root.left,没有被assign成self.intertTree(root.right)的value.
举个简单的栗子
a = 5
a, b = a + 5, a + 10
这个运行下来,a是10,b是15, 因为在运行a + 10的时候,a还没有被assign value 10.
如果这么写
a = 5
a = a + 5
b = a + 10
那么运行下来就是 a是10, b是20.
回复

使用道具 举报

qlan 2021-9-23 10:32:23 | 显示全部楼层
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   64% (88)
 
 
35% (49)    👎
这属于python expression evaluation order的问题,看doc

https://docs.python.org/3/refere ... ml#evaluation-order

> expr3, expr4 = expr1, expr2
回复

使用道具 举报

 楼主| ATPtennis 2021-9-23 11:34:53 来自APP | 显示全部楼层
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   93% (28)
 
 
6% (2)    👎
cloudero 发表于 2021-09-22 18:00:51
我猜测你的意思是 因为写到了一行,所以self.invertTree(root.right)和self.intertTree(root.left)不分先后同时运行。如果你是这么理解的话,那不对。如果不
非常清楚!这下彻底明白了!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表