查看: 3057| 回复: 24
跳转到指定楼层
上一主题 下一主题
收起左侧

[CareerCup] [第二轮] 3/11-3/17 CareerCup 4.1

全局:

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

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

x
Implement a function to check if a binary tree is balanced. Forthe purposes of this question, a balanced tree is defined to be a tree suchthat the heights of the two subtrees of any node never differ by more than one.



上一篇:[第二轮] 3/11-3/17 CareerCup 3.7
下一篇:[第二轮] 3/11-3/17 CareerCup 4.2
🔗
zuohr 2013-3-10 22:04:14 | 只看该作者
全局:
递归法分别计算左右子树的高度并比较。
有一个问题求大神解答, C++中树的操作很多时候都要把指向节点的指针的引用作为参数传递,但是Java木有引用类型,我这里只能用传递一个长度为1的数组的方法,但是看着很丑。。。请问有更好的方法么?
https://gist.github.com/Zuohr/5128625
回复

使用道具 举报

🔗
moophis 2013-3-11 12:00:59 | 只看该作者
全局:
Implemented this function in both recursive and non-recursive ways.
https://github.com/moophis/careercup/blob/master/4.1.cpp
回复

使用道具 举报

🔗
sing1ee 2013-3-11 22:30:50 | 只看该作者
全局:
zuohr 发表于 2013-3-10 22:04
递归法分别计算左右子树的高度并比较。
有一个问题求大神解答, C++中树的操作很多时候都要把指向节点的指针 ...

直接用引用就行了啊。为什么要用数组?java是传值的,那也是引用的本身。

回复

使用道具 举报

🔗
sing1ee 2013-3-11 22:34:30 | 只看该作者
全局:
zuohr 发表于 2013-3-10 22:04
递归法分别计算左右子树的高度并比较。
有一个问题求大神解答, C++中树的操作很多时候都要把指向节点的指针 ...

而且,这个算法有问题的呀。如下二叉树
----------------a
-----------b---------c
-------d------------------e
---f
不平衡。
回复

使用道具 举报

🔗
sing1ee 2013-3-11 22:50:43 | 只看该作者
全局:
回复

使用道具 举报

🔗
zuohr 2013-3-12 11:31:51 | 只看该作者
全局:
本帖最后由 zuohr 于 2013-3-12 11:33 编辑
sing1ee 发表于 2013-3-11 22:34
而且,这个算法有问题的呀。如下二叉树
----------------a
-----------b---------c


多谢提醒,已经更新了代码。
至于引用的问题,可能是我没说清楚,我是想在method中改变传递过来引用所指向的对象(这样方便用递归法来做很多涉及指针的数据结构的操作),而不仅是改变所指向的对象的field或者调用所指向对象的method。Java确实是传值的,所以传递的不是引用本身,而是引用的一个拷贝,有点类似于C++中的argument type的*ptr和&*ptr的区别,Java支持*ptr,而不支持&*ptr。下面这段代码可能可以说明我想说的问题:
https://gist.github.com/Zuohr/5140043
回复

使用道具 举报

🔗
sing1ee 2013-3-12 11:43:36 | 只看该作者
全局:
本帖最后由 sing1ee 于 2013-3-12 11:45 编辑
zuohr 发表于 2013-3-12 11:31
多谢提醒,已经更新了代码。
至于引用的问题,可能是我没说清楚,我是想在method中改变传递过来引用所 ...

恩,对的,参数传入引用,是无法修改的。不过引用所指的属性修改了,是可以保留的。这点和c++确实不一样,c++的参数可以作为返回值用。
回复

使用道具 举报

🔗
starcroce 2013-3-14 12:52:48 | 只看该作者
全局:
https://github.com/starcroce/car ... r/careercup_4_1.cpp
二叉树的第一反应还是递归。。。第一次写的时候有很奇怪的segmentation fault,然后朋友发现是leaf node的子节点没有设置null。。。姿势水平不够啊。。。
回复

使用道具 举报

🔗
grassgigi 2013-3-16 05:15:44 | 只看该作者
全局:
直接递归思路..
写了个helper function to build tree by pre-order and in-order sequences, 方便测试
https://gist.github.com/chrislukkk/def7f8695649501d14a6
回复

使用道具 举报

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

本版积分规则

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