热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

BST删除重复键实现,非递归实现

PBSTNodedeleteRRR(PBSTNodeh,Keyv){删除一个匹配的键值,如果有重复的键,将删除if(hz){return

PBSTNode deleteRRR(PBSTNode h,Key v)

{//删除一个匹配的键值,如果有重复的键,将删除

   if (h == z)

    {

       return h;

    }

    

   PBSTNode p = h;

   PBSTNode parent = NULL;

   while (p != z)

    {

       if (p->data

        {

            parent = p;

            p = p->right;

        }

       else if (p->data > v)

        {

            parent = p;

            p = p->left;

        }

       else if (p->data == v)

        {

           if (parent)

            {

               PBSTNode x = p;

               if (parent->data > v)

                {

                    parent->left =joinLR(p->left,p->right);

                    p = parent->left;

                }

               else if (parent->data

                {

                    parent->right =joinLR(p->left,p->right);

                    p = parent->right;

                }

               free(x);

            }

           else

            {

               PBSTNode x = p;

                h =joinLR(p->left,p->right);

               free(x);

                p = h;

            }

        }

    }

    

   return h;

}



推荐阅读
author-avatar
1994-MMMs
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有