当前位置: 首页 > wzjs >正文

上海移动官网网站建设今日资讯最新消息

上海移动官网网站建设,今日资讯最新消息,什么网站可以做PS 写论文兼职,服装店网站建设思路二叉搜索树 二叉搜索树结构二叉搜索树插入二叉搜索树的查找二叉搜索树的删除二叉搜索树中序便利二叉搜索树默认成员函数实现 二叉搜索树结构 template<class K, class V> class BinarySeacherTreeNode { public:BinarySeacherTreeNode(K Key new K, V Val new V) :left…

二叉搜索树

  • 二叉搜索树结构
  • 二叉搜索树插入
  • 二叉搜索树的查找
  • 二叉搜索树的删除
  • 二叉搜索树中序便利
  • 二叉搜索树默认成员函数实现


二叉搜索树结构


template<class K, class V>
class BinarySeacherTreeNode
{
public:BinarySeacherTreeNode(K Key = new K, V Val = new V) :left(NULL), right(NULL), key(Key), val(Val) {}BinarySeacherTreeNode* left;BinarySeacherTreeNode* right;K key;V val;
};
template<class K, class V>
class BinarySeacherTree
{
public:using Node = BinarySeacherTreeNode<K, V>;
private:Node* head = NULL;

二叉搜索树插入


插入思路:
定义一个cur指针和一个parent指针;插入的key比cur指向的key大就往右边走cur走一次parent跟新知道cur为空此时判断parent的key和要插入的key的大小来决定插入左边还是右边

bool Insert(const K& key, const V& val)
{if (head == NULL){head = new Node(key, val);return true;}Node* parent = head;Node* cur = head;while (cur){if (key > cur->key){parent = cur;cur = cur->right;}else if (key < cur->key){parent = cur;cur = cur->left;}else{return false;}}//上面循环就是找到插入的父节点//下面还要判断插入父节点的左右孩子cur = new Node(key, val);if (parent->key < key){parent->right = cur;}else{parent->left = cur;}return true;
}

二叉搜索树的查找


查找思路:
如果查找的key大于当前节点的key就去右边反之左边,相等返回该节点
直到cur为空还没找到就返回空指针

Node* Find(const K& key)
{Node* cur = head;while (cur){if (cur->key < key){cur = cur->right;}else if (cur->key > key){cur = cur->left;}else{return cur;}}//cout << "找不到" << endl;return NULL;
}

二叉搜索树的删除


删除思路:

  1. 先找到要删除的节点
  2. 判断要删除的节点有结构孩子
  1. 删除的节点有一个或一个孩子
    该情况如下:
    在这里插入图片描述
    至于0个孩子节点可以看做有一个空节点进行处理
    我们找到只需要把parent指向cur的孩子这里还要进行判断首先就是看cur是parent的左孩子还是右孩子,之后在判断cur的那一个孩子是哪一个最后进行连接即可
    注意:
    这时候我们要考虑删除的是根节点的话我们直接改变根节点的指向就可以了
  2. 删除的节点有两个节点
    该情况如下:
    在这里插入图片描述
    此时我们要进行代替法就是找cur的右树中最左端的节点或者左子树最右端的节点交换里面的值然后删除代替的那个节点即可
bool Erase(const K& key)
{Node* cur = head;Node* parent = head;while (cur){if (key > cur->key){parent = cur;cur = cur->right;}else if (key < cur->key){parent = cur;cur = cur->left;}else{//1.删除的节点有2个孩子if (cur->left && cur->right){//去右树找找左的节点来代替然后析构该节点Node* replaceparent = cur;Node* replace = cur->right;while (replace->left){replaceparent = replace;replace = replace->left;}cur->val = replace->val;if (replaceparent->right == replace){replaceparent->right = replace->right;delete replace;replace = NULL;}else{replaceparent->left = replace->right;delete replace;replace = NULL;}}//2.删除的节点有0或1个孩子else{//如果删除的是根节点直接跟新我们的根节点if (cur == head){if (cur->left) head = cur->left;else head = cur->right;}else{if (parent->left == cur){if (cur->left) parent->left = cur->left;else parent->left = cur->right;}else{if (cur->left) parent->right = cur->left;else parent->right = cur->right;}}}return true;}}return false;
}

二叉搜索树中序便利


void InOrder()
{_inorder(head);
}
void _inorder(Node* head)
{if (head == NULL)return;_inorder(head->left);cout << "key:" << head->key << " val:" << head->val << " ";_inorder(head->right);
}

二叉搜索树默认成员函数实现


拷贝构造函数:

BinarySeacherTree(const BinarySeacherTree& b)
{this->head = createtree(b.head);
}
Node* createtree(Node* hea)
{if (hea == NULL) return nullptr;Node* root = new Node(hea->key, hea->val);root->left = createtree(hea->left);root->right = createtree(hea->right);return root;
}

赋值重载:

BinarySeacherTree<K, V> operator=( BinarySeacherTree<K, V> tem)
{//这里参数不要传入引用std::swap(head, tem.head);return *this;
}

析构函数:

~BinarySeacherTree()
{destory(head);head = NULL;
}
void destory(Node* hea)
{if (hea == NULL)return;destory(hea->left);destory(hea->right);delete hea;hea = NULL;
}
http://www.dtcms.com/wzjs/50631.html

相关文章:

  • 成都疫情最新消息今天又封了上海seo公司哪个靠谱
  • 做视频网站公司要怎么做的国家职业技能培训官网
  • 天河公司网站建设万网域名官网
  • 株洲发布百度seo优化怎么做
  • 沈阳网站建设公司排名搜索引擎优化排名技巧
  • wordpress 页面 分栏网络营销中的seo与sem
  • php数据库的网站模板产品推广策划
  • 政府网站手机版建设方案正规seo排名多少钱
  • 汉川网站建设seo研究
  • 可以接项目做的网站全网关键词优化公司哪家好
  • 21dove谁做的的网站天津优化加盟
  • 网络营销策划案模板保定seo外包服务商
  • 上海网站备案在哪里查询填写电话的广告
  • 昆明做网站设计营销模式有几种
  • 仁怀哪儿做网站品牌推广的具体方法
  • 什么软件 做短视频网站好如何自己建设网站
  • 怎样做ppt下载网站安阳企业网站优化外包
  • 天津网站开发建设企业网络营销方案设计
  • 自媒体推广平台有哪些长春seo排名
  • 教育培训营销型网站建设哪家好互联网推广运营
  • 金坛建设局网站游戏推广员骗局
  • 做网站服务器怎么用潍坊疫情最新消息
  • 摄影培训网站建设互联网营销专家
  • 公司电子产品网站模板北京疫情太严重了
  • 企业网站需求方案百度代发排名
  • 贵州中小型营销型网站建设公司seo是指什么意思
  • 中国化工建设网站365优化大师软件下载
  • 网站建设茂名成都网络营销推广
  • 自建网站有哪些正规软件开发培训学校
  • 易龙天做的网站怎么样网络营销期末考试题库