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

上海移动官网网站建设抖音代运营收费详细价格

上海移动官网网站建设,抖音代运营收费详细价格,安装php和mysql网站,wordpress 导航跳转二叉搜索树 二叉搜索树结构二叉搜索树插入二叉搜索树的查找二叉搜索树的删除二叉搜索树中序便利二叉搜索树默认成员函数实现 二叉搜索树结构 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/288061.html

相关文章:

  • 台州网站建设 网站制作 网站设计石家庄头条今日头条新闻
  • 昆明优化网站商品seo关键词优化
  • java如何对网站做压力测试《新闻联播》 今天
  • 龙岗汤坑社区网站建设微信加精准客源软件
  • 公益网站怎么做百度一下你知道
  • 我要注册邮箱独立站seo
  • wordpress在线报名插件seo伪原创工具
  • wordpress按照视频佛山市seo推广联系方式
  • 制作xml网站地图文件站长工具视频
  • 深圳企业信息查询网seo收费
  • 做美食网站视频互联网广告价格
  • 网络电子商务购物网站关键词优化包含
  • 网站建设评语口碑营销怎么做
  • 帮做钓鱼网站会怎样中国新冠疫苗接种率
  • 门户网站建设方法南京网站制作
  • 什么网站可以自己接工程做预算百度在线识别图片
  • 网络网站建设电话西安seo霸屏
  • 可以做海报的网站seo推广小分享
  • 南京哪家网络公司做网站优化好长沙今日头条新闻
  • 企业解决方案ppt10页seo优化师就业前景
  • 遵义公司做网站找哪个公司好上海网络推广公司
  • 网站一般用什么工具做seo外包公司兴田德润
  • 协会网站方案百度官网首页入口
  • 陕西营销型网站建设宁波seo资源
  • 湛江建站程序短视频拍摄剪辑培训班
  • 宁波网站建设怎么样淘宝网络营销方式
  • 程序员 创业做网站seo点击排名器
  • 响应式网站什么意思怎样做好销售和客户交流
  • 网站建设在哪个软件下做googleseo排名公司
  • 榆林做网站上海十大营销策划公司排名