楼主: nice_lady802
跳转到指定楼层
上一主题 下一主题
收起左侧

Facebook 2/28电面面经

🔗
 楼主| nice_lady802 2017-3-3 05:13:11 | 只看该作者
全局:
adrianliu729 发表于 2017-3-3 04:49
奥懂了懂了,谢谢!是加上该节点一共的sum

对对对~~我没描述清楚。。太忧伤了。。

评分

参与人数 1大米 +3 收起 理由
lixz0087 + 3 谢谢你的介绍!

查看全部评分

回复

使用道具 举报

🔗
 楼主| nice_lady802 2017-3-3 05:13:40 | 只看该作者
全局:
PEDOT 发表于 2017-3-3 05:06
请问如果是这样一种情况怎么办呢?

             1

删掉2,7,-9

评分

参与人数 1大米 +3 收起 理由
lixz0087 + 3 很有用的信息!

查看全部评分

回复

使用道具 举报

🔗
adrianliu729 2017-3-3 05:25:52 | 只看该作者
全局:
        public static int remove(TreeNode root) {
                if(root == null) return 0;
               
                int sum = 0;
                Iterator<TreeNode> iter = root.children.iterator();
                while(iter.hasNext()) {
                        TreeNode child = iter.next();
                        int childSum = remove(child);
                        if(childSum == 0) {
                                iter.remove();
                        }
                        sum += childSum;
                }
                return sum;
        }


补充内容 (2017-3-3 05:26):
楼主请帮忙看下。谢谢了!
回复

使用道具 举报

🔗
 楼主| nice_lady802 2017-3-3 05:29:15 | 只看该作者
全局:
adrianliu729 发表于 2017-3-3 05:25
public static int remove(TreeNode root) {
                if(root == null) return 0;
               

int sum = root.val;

评分

参与人数 1大米 +3 收起 理由
lixz0087 + 3 很有用的信息!

查看全部评分

回复

使用道具 举报

🔗
 楼主| nice_lady802 2017-3-3 05:29:44 | 只看该作者
全局:
PEDOT 发表于 2017-3-3 05:26
就是这个root下面所有的节点之和了吗?

如果是这样的话,我是想先定义这样的一个node:先dfs求出所有的 ...

TreeNode 里面只能有val和children信息,不能有sum

评分

参与人数 2大米 +8 收起 理由
潜水小鱼 + 5 欢迎来介绍你知道的情况
lixz0087 + 3 有道理

查看全部评分

回复

使用道具 举报

🔗
adrianliu729 2017-3-3 05:37:31 | 只看该作者
全局:

啊对对对,看错了。谢谢!
回复

使用道具 举报

🔗
mingzhou1987 2017-3-3 13:41:56 | 只看该作者
全局:
写了个二叉树的, 这样可以否?
TreeNode* delete(TreeNode* root)
{
  if(!root)return NULL;
  int leftSum = sumTree(root->left);
  int rightSum = sumTree(root->right);
  if(leftSum + rightSum + root->val == 0)return NULL;
  if(leftSum == 0)root->left = NULL;
  if(rightSum == 0)root->right = NULL;
  delete(root->left);
  delete(root->right);
  return root;
}
int sumTree(TreeNode* root)
{
  if(!root)return 0;
  return (root->val + sumTree(root->left) + sumTree(root->right);
}
回复

使用道具 举报

🔗
uestcxzk 2017-3-3 14:02:30 | 只看该作者
全局:
我觉得要在root上方再加个dummy,否则root如果满足条件的话删不掉
回复

使用道具 举报

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

本版积分规则

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