博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
二叉查找树 循环非递归实现
阅读量:6323 次
发布时间:2019-06-22

本文共 3013 字,大约阅读时间需要 10 分钟。

#ifndef __BINARY_SEARCH_H__#define __BINARY_SEARCH_H__#include 
#include
template
class BinarySearchTree;template
std::ostream& operator<<(std::ostream &out, BinarySearchTree
&);template
class BinarySearchTree { friend std::ostream& operator<<
(std::ostream &out, BinarySearchTree
&tree); struct Node { Key key; Value val; Node *left; Node *right; Node(Key pkey, Value pval):key(pkey), val(pval), left(nullptr), right(nullptr) {} }; Node *root; void traverse(Node *node, std::ostream &out) { if (node == nullptr) return; traverse(node->left, out); out << "(" << node->key << ", " << node->val << ") "; traverse(node->right, out); }public: BinarySearchTree(Key pkey, Value pval) :root(new Node(pkey, pval)) {} void put(Key key, Value val) { Node **node = &root; while (*node != nullptr) { if (key < (*node)->key) node = &((*node)->left); else if (key > (*node)->key) node = &((*node)->right); else return; } if(*node == nullptr) *node = new Node(key, val); } Value get(Key key) { Node *node = root; while (node != nullptr) { if (key < node->key) node = node->left; else if (key > node->key) node = node->right; else return node->val; } assert(false); } Node* deleteMin(Node* head) { if (head == nullptr) return nullptr; Node *node = head; Node *lastNode = nullptr; while (node->left != nullptr) { lastNode = node; node = node->left; } lastNode->left = node->right; //delete node; return head; } Node* min(Node *head) { if (head == nullptr) return nullptr; Node *node = head; while (node->left != nullptr) node = node->left; return node; } void deleteNode(Key key) { Node *lastNode = nullptr; Node *node = root; Node *newNode = nullptr; while (node != nullptr) { if (key < node->key) { lastNode = node; node = node->left; } else if (key > node->key) { lastNode = node; node = node->right; } else { Node **plastNode = nullptr; // 注意树根 if (lastNode == nullptr) plastNode = &root; else plastNode = &lastNode; // 无节点的情况 if (node->left == nullptr && node->right == nullptr) { if ((*plastNode)->left == node) { (*plastNode)->left = nullptr; delete node; return; } else if ((*plastNode)->right == node) { (*plastNode)->right = nullptr; delete node; return; } } // 只有一个节点的情况 if (node->left == nullptr) { if ((*plastNode)->left == node) { (*plastNode)->left = node->right; delete node; return; } else if ((*plastNode)->right == node) { (*plastNode)->right = node->right; delete node; return; } } if (node->right == nullptr) { if ((*plastNode)->right == node) { (*plastNode)->right = node->left; delete node; return; } else if ((*plastNode)->left == node) { (*plastNode)->left = node->left; delete node; return; } } // 两个节点的情况 Node *star = min(node->right); star->right = deleteMin(node->right); star->left = node->left; } } }};template
std::ostream& operator<<(std::ostream &out, BinarySearchTree
&tree){ tree.traverse(tree.root, out); return out;}#endif

 

转载于:https://www.cnblogs.com/sdlwlxf/p/5001515.html

你可能感兴趣的文章
node mysql模块写入中文字符时的乱码问题
查看>>
分析Ajax爬取今日头条街拍美图
查看>>
内存分布简视图
查看>>
如何学习虚拟现实技术vr? vr初级入门教程开始
查看>>
第4 章序列的应用
查看>>
初识闭包
查看>>
hdu1874畅通工程续
查看>>
rails 字符串 转化为 html
查看>>
AOP动态代理
查看>>
Yii2.0 下的 load() 方法的使用
查看>>
iOS8 Push Notifications
查看>>
各大名企笔试及面经大全(程序猿必读)
查看>>
轨磁条简介
查看>>
如何设计高扩展的在线网页制作平台
查看>>
SpringBoot整合MyBatis
查看>>
Android 类库书签更新(一)
查看>>
简单的一条SQL,不简单的做事思维 NOT IN 、NOT EXISTS、LEFT JOIN用法差别 ...
查看>>
DataWorks:任务未运行自助排查
查看>>
「镁客早报」特斯拉裁员,马斯克解释没有办法;微软推出Azure DevOps赏金计划...
查看>>
centos 7.4 使用 pgxc_ctl 安装与使用
查看>>