📣 VIP通行证夏日特惠 限时立减$68
12
返回列表 发新帖
楼主: 金妮韦崽
跳转到指定楼层
上一主题 下一主题
收起左侧

TripAdvisor电面面经,目测已杯具

🔗
fengyu225 2015-7-9 10:45:27 | 只看该作者
全局:
可以用morris traversal,非递归并且常数空间

int count_duplicates(TreeNode* root){
    if(!root) return 0;
    TreeNode* pre = NULL;
    TreeNode* curr = root;
    int res = 0;
    while(curr){
        if(curr->left){
            TreeNode* x = curr->left;
            while(x->right && x->right != curr) x=x->right;
            if(x->right == curr){
                x->right = NULL;
                if(pre && pre->val == curr->val) res++;
                pre = curr;
                curr = curr->right;
            }
            else{
                x->right = curr;
                curr = curr->left;
            }
        }
        else{
            if(pre && pre->val == curr->val) res++;
            pre = curr;
            curr = curr->right;
        }
    }
    return res;
}
回复

使用道具 举报

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

本版积分规则

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