计蒜客课程竞赛入门--二叉搜索树 流程记

二叉搜索树插入删除演示地址:

http://www.cs.usfca.edu/~galles/visualization/BST.html

细心的你应该发现了,二叉搜索树的每个节点都要比左边的子孙节点的值要大,比右边的要小。二叉搜索树的中序遍历就是将整棵树按从小到大的顺序输出。是不是很神奇^o^

如何在二叉搜索树中查找某个元素呢?首先从根出发,如果和根的值相等,则返回根,否则如果比根小就去左孩子,如果比根大就去右孩子,依次递归进行,直到找到值或者找不到返回空。

那么插入操作呢?紧接着上面的查找算法,在查找失败的时候插入到对应的位置即可。

删除操作会复杂一些,算法如下:

如果没有儿子:直接删除;

如果只有一个儿子:删除后将儿子放在该节点的位置;

有两个儿子:需要从右子树中找到其中的最小值并删除,并将最小值赋值给当前待删除节点。如下图所示:

另外还有线段树,并查集.

时间: 2024-08-06 11:44:42

计蒜客课程竞赛入门--二叉搜索树 流程记的相关文章

计蒜客课程竞赛入门--蒜头学算数 流程记

蒜头的数学实在是太差了,于是老师把他关到小黑屋让他闭门修炼.老师跟他一张纸,上面一 排写着1, 2, 3...N这N个数,中间用空白分隔.老师让他在空白处填上加号或者减号.他让蒜头君求出一共有多少种加运算符的方法使得整个表达式的值为0,并输出所有 的方案.比如N=7时,1 2 3 4 5 6 7排成一排,一种插入符号的方案为1+2-3+4-5-6+7=0.是不是很有趣,快来帮蒜头君解出这题吧(*´▽`)?? 输入为一行,包含一个整数N(3≤N≤9). 输出为所有在每对数字间插入“+”或“-”后能

计蒜客课程竞赛入门--统计三角形 代码流程摘记

1 #include<iostream> 2 #include<cstdio> 3 #include<cstring> 4 using namespace std; 5 int n,l[15];//n:木棍数量,l数组:每根木棍长度 6 bool h[10000]; 7 /* 8 因为三条边长度是确定的,所以确定两条边就可以,且,这个数组是用哈希表来储存 9 储存方式为第一条边长度*100+第二条边长度,最高位99*100+99=9999,故存10000 10 */ 1

计蒜客课程竞赛入门--冗余关系(并查集) 流程记

蒜头最近在沉迷小说,尤其是人物关系复杂的言情小说.它看到的人物关系描述得很的麻烦的时候觉得非常蒜疼,尤其是人物关系里有冗余的时候.什么是冗余关系呢? 这篇小说里有n句描述人物关系的句子,描述了n个人的关系. 每条句子的定义是这样的: X<->Y    它的意思是:X认识Y,Y也认识X 我们认为小说中的人物关系是具有传递性的,假如A认识B,B认识C,则A也认识C. 冗余关系的定义:就是即使没有这条人物关系,原来的人物之间的所有关系也照样成立. 比如: 小说中已经提到了A认识B,B也认识C.在此之

计蒜客课程竞赛入门--最近通话记录(STL队列) 流程记

蒜头君前几天把最心爱的小麦手机摔坏了,新手机又要好几天才能到货,于是蒜头君不得暂时用它珍藏已久的诺鸡鸭非智能手机了.手机的存储空间非常小,以至于未接来电.已接来电和已拨电话都只能各自保存最近的10条记录. 蒜头买了手机以后的未接来电.已接来电和已拨电话记录全部给出.机智的蒜头能够猜到这个手机使用了循环队列来实现最近记录的功能,不过它不会写代码(没手怎么写π_π),于是它来求助正在算法课程中过关斩将的你了.你能帮帮它吗? 输入格式: 每条记录包含两个数字,第一个数代表记录类型,第二个数代表手机号码

计蒜客课程竞赛入门--堆排序 流程记

堆实际上是一颗二叉树,对于大根堆来说,它的特点就是父节点的值大于所有子节点的值. C++的STL中priority_queue已经帮我们实现好了堆的数据结构,接下来我们一起学习并实践如何实现一个堆并用堆进行排序. priority_queue是STL的queue这个头文件中定义的数据结构,因此需要额外引用它,即#include <queue>. 1 #include <iostream> 2 #include <cstdio> 3 #include <queue&

计蒜客课程竞赛入门--数塔问题(DP) 流程记

还记得上一节提到的数塔问题么?我们接下来一起解决它吧.          9       12 15     10  6  8   2  18  9  519  7  10  4  15上面这张图是一个数塔问题的例子.每次从顶部元素,就是上图中的9出发,每次可以走到下面相邻的两个节点,比如从9往下相邻的是12和15,6往下相邻的是18和9.找到一条从顶部到底部的路径,使得路径上的数值和最大. 一个直观的贪心策略是每次向下走都选择较大的那一个,得到的一个解是9+15+8+9+10=51,然而我们发

计蒜客课程竞赛入门--最长上升子序列(LIS) 流程记

最长上升子序列 (Longest Increasing Subsequence, 常简称为 LIS) 是动态规划解决的一个经典问题. 我们先讲一下子序列是什么.一个数组的子序列就是从里面选出一些元素,并将他们保持原有的先后顺序排列.比如[1, 2, 3, 4, 5]的子序列有[1, 3, 5].[3, 4],而[1, 5, 3]则不是这个数组的子序列. 这里多介绍一下,还有一个容易与子序列混淆的概念:子串.子串是指从一个数组中选出连续的一个或多个元素,并且保持他们原有的顺序.子串一定是子序列,比

牛客 看看数组是不是二叉搜索树的后序遍历序列

class Solution {   bool judge(vector<int>& a, int left, int right) {    if(left>=right) return true;      int i=right; //此时数组的right就是根 while(i>left&&a[i-1]>a[right]) --i; //找到左子树,i-1就是左子树根      for(int j=i-1;j>=left;--j) if(a

计蒜客 课程学分总数

题目链接  课程学分总数 很基础的树型DP.注意输入数据可能是森林而不是完整的一棵树. 那么给所有没有祖先的点加一个公共的根就好了. #include <bits/stdc++.h> using namespace std; #define rep(i, a, b) for (int i(a); i <= (b); ++i) #define dec(i, a, b) for (int i(a); i >= (b); --i) typedef long long LL; const