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

阿泰勒北京网站建设大型网站化方案

阿泰勒北京网站建设,大型网站化方案,建设网站遇到的问题,涪陵网站建设B树和B树的区别 B树,也即balance树,是一棵多路自平衡的搜索树。它类似普通的平衡二叉树,不同的一点是B树允许每个节点有更多的子节点。 B树内节点不存储数据,所有关键字都存储在叶子节点上。B树: B树: 二叉…
  1. B树和B+树的区别
    • B树,也即balance树,是一棵多路自平衡的搜索树。它类似普通的平衡二叉树,不同的一点是B树允许每个节点有更多的子节点。
  • B+树内节点不存储数据,所有关键字都存储在叶子节点上。
  • B树:
  • B+树:

    二叉树理论基础:

    1.种类:满二叉树、完全二叉树、二叉搜索树、平衡二叉树。

    完全二叉树是最后一行从左到右连续但不一定全满。

    二叉搜索树,必须有一定顺序。查询和添加都是O(logn),因为添加就是查询的过程。

    平衡二叉搜索树:左右子树高度差的绝对值不超过1。map,set,multimap,multiset底层都是平衡二叉搜索树(是红黑树,红黑树是一种平衡二叉搜索树。)

    2.存储方式:链表、数组。

    链表,就是val,Treenode* left, Treenode *right

    数组,一开始从0开始,左孩子就是2k+1,右孩子就是2k+2

    3.遍历方式:

    深度优先搜索:前序(中左右)、中序(左中右)、后序(左右中)。一般用递归实现,也可以迭代实现。

    广度优先搜索:层序遍历是其中一种。

    图的深度优先搜索就对应树的前中后序,图的广度优先搜索就对应树的层序遍历。

    1. 二叉树的前,中,后序遍历 - 递归 leetcode144.94.145 20231026

    代码随想录又卡了,栈与队列最后那题打着C++已实现的优先队列的旗号实际上是堆,而堆本身又是完全二叉树.....优先队列那题还不是直接拿的priority_queue去实现的,还自定义了它的比较规则,这又引出一个函数对象的概念,总之是无从下手,遂转战二叉树。今天看了看二叉树的理论知识,感觉还行,结果写题的时候又被递归摆了一道,完全忘了return和题干给的函数有什么用。

    总之,题干给的preorderTraversal没动,自己重新实现了一个函数,调用之即可。下面两题是类似的。

    class Solution {
    public:void preorder(TreeNode* cur, vector<int>& vct) {if(cur == nullptr){return;}vct.push_back(cur->val);preorder(cur->left,vct);preorder(cur->right,vct);}vector<int> preorderTraversal(TreeNode* root){vector<int> vct;preorder(root,vct);return vct;}};

    2. 二叉树的前,中,后序遍历 - 迭代leetcode144.94.145 20231027

    迭代分为前后,中两种,理解起来其实还是很困难的,看代码貌似记住了,自己写对了,但是再过几天让我写是绝对写不出来的

    前后之所以说是“一种”,因为后序可以由前序倒一下左右,再reverse一下数组就能得到。他们遍历和处理的顺序都是一样的,而中序就不一样了。

    下面来看一下具体的代码~

    前序,后序在这里就只放前序了:

    
    class Solution {
    public:vector<int> preorderTraversal(TreeNode* root) {stack<TreeNode*> stk;vector<int> vct;if(root == nullptr)return vct;stk.push(root);while(!stk.empty()){TreeNode* cur = stk.top();stk.pop();vct.push_back(cur->val);if(cur->right !=nullptr)stk.push(cur->right);if(cur->left !=nullptr)stk.push(cur->left);}return vct;}
    };

    定义一个stk用于模拟递归,一个vct用户返回数组。因为要先push root进去,所以先得判断一下是否为空。

    root被push进去以后,只要栈不为空,就pop栈顶出来,再把刚出的栈顶push到 vct 里面去,然后先往栈里push右边,再往栈里push左边。这样的话,之后vct就会从栈顶开始出,就会先被push_back到vct里面去,而后又是往复的右左栈入,中(栈里元素)左右vct出。

    中序

    class Solution {
    public:vector<int> inorderTraversal(TreeNode* root) {vector<int> vct;stack<TreeNode*> stk;TreeNode* cur = root;while(cur != nullptr || !stk.empty()){if(cur != nullptr){stk.push(cur);cur = cur->left;//入栈,然后cur一直到最左边}else{cur = stk.top();//已经为空了,就取栈头的成为现在的curstk.pop();vct.push_back(cur->val);cur = cur->right;}}return vct;}
    };

    未完待续

http://www.yayakq.cn/news/139882/

相关文章:

  • 中国网站制作 第一个网站头像有啥做会清晰
  • 中卫网站设计盘锦网站网站建设
  • flash网站做seo优化好不好个人信息怎么在百度推广
  • 模板网站有利于优化最大的房产网站
  • 无锡网站推广¥做下拉去118cr网站宽度980 在ipad上 左对齐了
  • 免费建站平台哪个好安康市燃气公司电话
  • 深圳做网站的公司哪家好域名买好了怎么做网站
  • dedecms网站如何上线免费的企业网站
  • 江西建设厅培训网站友情链接查询
  • wordpress网站特别卡左侧菜单 网站
  • 用asp.net开发网站的优势永信南昌网站建设
  • 建设租房信息网站计算机培训班推荐
  • 网站公司销售怎么做重庆网站建设子沃科技熊掌号
  • 网站后台更新无法在网页显示给公司做网站需要什么信息
  • 江西建设三类人员网站上海松江区网站建设
  • 百度权重高的网站有哪些盐城市城市建设投资公司网站
  • 网站建设 验收意见vue做企业网站
  • 外贸响应式网站设计怎么在ftp中查看网站首页路径
  • 做任务可以给钱的网站网站编辑
  • 遂宁商城网站建设方案闵行网站建设推广
  • 传奇高端网站设计制作如何网站开发
  • 网站排名优化seo联盟设计库
  • 清流县建设局网站最珠海app
  • 电商网站建设心得体会动漫网页设计论文
  • 猪八戒网站建设公司江苏省建设安全协会网站
  • python网站开发招聘头条新闻 最新消息条
  • 男朋友说是做竞彩网站维护的wordpress添加下载页
  • 南京建设人才网站制定商务网站建设时
  • 乌海网站制作福田网站开发
  • 做的网站太大有一个网站专门做民宿