📣 独立日限时特惠: VIP通行证立减$68
楼主: 匿名
跳转到指定楼层
上一主题 下一主题
收起左侧

🐶虚拟上门

全局:
如果time complexity要求不高的话应该不需要用到morris traversal,用最笨的方法用iterative的方式从root出发去找最左边的子节点,其实就是postorder去找。如果删除到root自己了,就把root改成右节点。时间复杂度O(N * H), 不需要额外memory。
回复

使用道具 举报

全局:
麻烦各位大佬看看,verify一下:
  1. void freeTree( TreeNode*& root ) {
  2.     while ( root != NULL ) {
  3.         TreeNode* cur = root;
  4.         TreeNode* parent = NULL;
  5.         while ( cur->left != NULL ) {
  6.             parent = cur;
  7.             cur = cur->left;
  8.             if ( cur->left == NULL ) {
  9.                 if ( cur->right != NULL ) {
  10.                     cur = cur->right;
  11.                 }
  12.             }
  13.         }
  14.         if ( parent == NULL ) {
  15.             TreeNode* tmp = root;
  16.             root = root->right;
  17.             delete tmp;
  18.             continue;
  19.         }
  20.         if ( parent->left != NULL ) {
  21.             parent->left = NULL;
  22.         } else {
  23.             parent->right = NULL;
  24.         }
  25.         delete cur;
  26.     }
  27. }
  28. int main() {
  29.     TreeNode* root = new TreeNode( -1 );
  30.     TreeNode* a = new TreeNode( 0 );
  31.     TreeNode* b = new TreeNode( 1 );
  32.     TreeNode* c = new TreeNode( 2 );
  33.     TreeNode* d = new TreeNode( 3 );
  34.     TreeNode* e = new TreeNode( 4 );
  35.     TreeNode* f = new TreeNode( 5 );
  36.     root->left = a;
  37.     root->right = b;
  38.     a->left = c;
  39.     a->right = d;
  40.     b->left = e;
  41.     b->right = f;
  42.     freeTree( root );
  43.     assert ( root == NULL );
  44. }
复制代码
回复

使用道具 举报

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

本版积分规则

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