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

视频教做家常菜的网站wordpress社交模板

视频教做家常菜的网站,wordpress社交模板,恐怖音乐怎么做的视频网站,福州网站设计培训这部分主要是用代码实现有序二叉树、树遍历、删除节点 目录 1.构建有序二叉树 1.1原理 1.2插入实现 2.广度优先遍历--队列实现 3.深度优先遍历--递归实现 3.1先序遍历 3.2中序遍历 3.3后序遍历 4.删除 4.1删除叶子节点 4.2删除有一棵子树的节点 4.3删除有两棵子树的节…

这部分主要是用代码实现有序二叉树、树遍历、删除节点

目录

1.构建有序二叉树

1.1原理

 1.2插入实现

2.广度优先遍历--队列实现

3.深度优先遍历--递归实现

3.1先序遍历

3.2中序遍历

3.3后序遍历

4.删除

4.1删除叶子节点

4.2删除有一棵子树的节点

4.3删除有两棵子树的节点

5.整体代码


1.构建有序二叉树

1.1原理

左边节点值小于父节点,右边节点值大于父节点,看下图

 1.2插入实现

当传入value值时,判断root节点是否为空:空的话建立新节点做root;不空,建立一个中间节点index,然后循环按照插入原理判断插到哪,代码如下:

 public void insert(int value){Node node = new Node(value);if(root==null){root = node;return;}Node index = root;while(true) {if(index.value>value) {//要插入的节点值小if(index.left==null) {//插入index.left=node;return;}index=index.left;}else{//要插入的节点值大if(index.right==null){index.right=node;return;}index=index.right;}}

2.广度优先遍历--队列实现

广度优先遍历就是层次遍历,使用队列实现。当队列中进入一个新节点,输出后就找这个节点的左右孩子入队。

代码如下:

    public void levelOrder() {Queue<Node> queue = new LinkedList<Node>();if(root!=null) {queue.add(root);}Node index;while (!queue.isEmpty()){index = queue.poll();System.out.print(index.value+Messages.getString("BinaryTree.0")); //$NON-NLS-1$if(index.left!=null){queue.add(index.left);}if(index.right!=null) {queue.add(index.right);}}System.out.println();}

3.深度优先遍历--递归实现

3.1先序遍历

就是根-左-右的顺序,使用递归实现,代码如下:

    /** 先序遍历*/public void beforeOrder(Node node){if(node==null) {return;}System.out.print(node.value+Messages.getString("BinaryTree.1"));beforeOrder(node.left);beforeOrder(node.right);}

3.2中序遍历

使用左-根-右顺序

    /** 中序遍历*/public void inOrder(Node node){if(node==null){return;}inOrder(node.left);System.out.print(node.value+Messages.getString("BinaryTree.2")); //$NON-NLS-1$inOrder(node.right);}

3.3后序遍历

使用左-右-根顺序,代码如下:

    /** 后序遍历*/public void afterOrder(Node node) {if(node==null) {return;}afterOrder(node.left);afterOrder(node.right);System.out.print(node.value+Messages.getString("BinaryTree.3")); }

4.删除

删除比较复杂,要分三种情况:

4.1删除叶子节点

  1. 找到目标节点:在二叉搜索树中定位要删除的目标节点target 。
  2. 找到父节点:确定target节点的父节点parent 。
  3. 判断父节点情况
    • 若无父节点,意味着target是根节点,直接将根节点置为null 。
    • 若有父节点,判断targetparent的左子还是右子:是左子就执行parent.left = null ;是右子就执行parent.right = null 。

需要额外写一个函数来寻找父节点,代码如下:

    /*** 找目标值的父节点*/public Node searchParent(int value) {if(root==null) {return null;}Node index = root;while (index!=null) {if((index.left!=null&&index.left.value==value)||(index.right!=null&&index.right.value==value)) {return index;}else if (index.value>value) {index=index.left;}else {index = index.right;}}return null;}

这部分代码如下:

		if(target.left==null&&target.right==null) {//叶子节点//没有父节点if(parent==null) {root=null;return;}//有父节点if(parent.left!=null&&parent.left.value==value) {parent.left=null;}else {parent.right=null;}}

4.2删除有一棵子树的节点

  1. 找到目标节点:确定要删除的节点target 。
  2. 找到父节点:找到target节点的父节点parent 。
  3. 判断父节点和子树情况
    • 若无父节点,即target是根节点,若target有左子树,让根节点指向其左子树(root = root.left );若有右子树,让根节点指向其右子树(root = root.right )。
    • 若有父节点,先确定targetparent的左子还是右子,再根据target自身有左子树还是右子树,调整parent相应子树指针(如parent.left = target.left 或parent.right = target.right )。

代码如下:

			//有一棵子树的节点//没有父节点if(parent==null) {//目标节点有左子树还是右子树if(target.left!=null) {root = root.left;}else {root=root.right;}return;}//有父节点//判断目标节点是父节点的左孩子还是右孩子if(parent.left!=null&&parent.left.value==value) {//左孩子//目标节点有左子树还是右子树if(target.left!=null) {parent.left = target.left;}else {parent.left = target.right;}}else {//右孩子//目标节点有左子树还是右子树if(target.left!=null) {parent.right = target.left;}else {parent.right = target.right;}}

4.3删除有两棵子树的节点

  1. 找到目标节点:定位要删除的节点target 。
  2. 替换节点选择:获取target左子树的最大值节点或者右子树的最小值节点作为替换节点。
  3. 删除目标节点:用选定的替换节点替代target节点的位置 ,并处理好相关子树连接关系(如parent.left = target.right 或parent.right = target.left 等)。

需要额外写一个判断最小值的函数:

	/*** 找树当中的最小值*/public int min(Node node) {Node index = node;while(index.left!=null) {index=index.left;}return index.value;}

 

代码如下:

 if(target.left!=null&&target.right!=null) {//有两棵子树的节点int minVal = min(target.right);delete(minVal);target.value = minVal;}

5.整体代码

代码如下:

package com.qcby.树;import java.util.LinkedList;
import java.util.Queue;public class BinaryTree {Node root;/*** 插入*/public void insert(int value){Node node = new Node(value);if(root==null){root = node;return;}Node index = root;while(true) {if(index.value>value) {//要插入的节点值小if(index.left==null) {//插入index.left=node;return;}index=index.left;}else{//要插入的节点值大if(index.right==null){index.right=node;return;}index=index.right;}}}/** 广度优先遍历*/public void levelOrder() {Queue<Node> queue = new LinkedList<Node>();if(root!=null) {queue.add(root);}Node index;while (!queue.isEmpty()){index = queue.poll();System.out.print(index.value+Messages.getString("BinaryTree.0")); //$NON-NLS-1$if(index.left!=null){queue.add(index.left);}if(index.right!=null) {queue.add(index.right);}}System.out.println();}/** 先序遍历*/public void beforeOrder(Node node){if(node==null) {return;}System.out.print(node.value+Messages.getString("BinaryTree.1")); //$NON-NLS-1$beforeOrder(node.left);beforeOrder(node.right);}/** 中序遍历*/public void inOrder(Node node){if(node==null){return;}inOrder(node.left);System.out.print(node.value+Messages.getString("BinaryTree.2")); //$NON-NLS-1$inOrder(node.right);}/** 后序遍历*/public void afterOrder(Node node) {if(node==null) {return;}afterOrder(node.left);afterOrder(node.right);System.out.print(node.value+Messages.getString("BinaryTree.3")); //$NON-NLS-1$}/** 查找*/public Node search(int value) {if(root==null) {return null;}Node index = root;while (index!=null) {if(index.value==value){return index;}else if(index.value>value) {index = index.left;}else {index=index.right;}}return null;}/*** 找目标值的父节点*/public Node searchParent(int value) {if(root==null) {return null;}Node index = root;while (index!=null) {if((index.left!=null&&index.left.value==value)||(index.right!=null&&index.right.value==value)) {return index;}else if (index.value>value) {index=index.left;}else {index = index.right;}}return null;}/*** 找树当中的最小值*/public int min(Node node) {Node index = node;while(index.left!=null) {index=index.left;}return index.value;}/*** 删除*/public void delete(int value){if(root==null) {System.out.println(Messages.getString("BinaryTree.4")); return;}//找目标节点Node target = search(value);if(target==null) {System.out.println(Messages.getString("BinaryTree.5")); return;}//找目标节点的父节点Node parent = searchParent(value);//三种情况,分情况讨论if(target.left==null&&target.right==null) {//叶子节点//没有父节点if(parent==null) {root=null;return;}//有父节点if(parent.left!=null&&parent.left.value==value) {parent.left=null;}else {parent.right=null;}}else if(target.left!=null&&target.right!=null) {//有两棵子树的节点int minVal = min(target.right);delete(minVal);target.value = minVal;}else {//有一棵子树的节点//没有父节点if(parent==null) {//目标节点有左子树还是右子树if(target.left!=null) {root = root.left;}else {root=root.right;}return;}//有父节点//判断目标节点是父节点的左孩子还是右孩子if(parent.left!=null&&parent.left.value==value) {//左孩子//目标节点有左子树还是右子树if(target.left!=null) {parent.left = target.left;}else {parent.left = target.right;}}else {//右孩子//目标节点有左子树还是右子树if(target.left!=null) {parent.right = target.left;}else {parent.right = target.right;}}}}@Overridepublic String toString() {return "BinaryTree [root=" + root + "]";}}

 


文章转载自:

http://9IulnH3P.bfgbz.cn
http://RBTJFpXx.bfgbz.cn
http://2qpi2JuU.bfgbz.cn
http://8FMGQe4U.bfgbz.cn
http://rjjbAJxH.bfgbz.cn
http://5c7EYLSY.bfgbz.cn
http://xwY25TYz.bfgbz.cn
http://jwBx9Axf.bfgbz.cn
http://4za44eNl.bfgbz.cn
http://rVWawRMw.bfgbz.cn
http://KUWoRshF.bfgbz.cn
http://Ql99edsm.bfgbz.cn
http://oUJBoQw8.bfgbz.cn
http://sWeCtd7q.bfgbz.cn
http://bXM3THk9.bfgbz.cn
http://GbTg95mK.bfgbz.cn
http://Dv5KJoLk.bfgbz.cn
http://ouhVMrGf.bfgbz.cn
http://y2K1Z4Hc.bfgbz.cn
http://aHQel1GV.bfgbz.cn
http://uh4ZiM1u.bfgbz.cn
http://J1ZkYQD7.bfgbz.cn
http://0ouK9dFN.bfgbz.cn
http://mh8Q5Rre.bfgbz.cn
http://vKnS2m2p.bfgbz.cn
http://aKW7CD8i.bfgbz.cn
http://QOvl8GJA.bfgbz.cn
http://vcTzeSkr.bfgbz.cn
http://74nKvjLT.bfgbz.cn
http://KtRYCZ47.bfgbz.cn
http://www.dtcms.com/wzjs/768509.html

相关文章:

  • 建设部人才网站黄骅港船舶动态信息平台
  • 马鞍山市网站建设服务有限公司深圳网站排名
  • 凡科建的网站可以做seo吗ppt设计网站
  • 新密网站建设wordpress移动端音频播放
  • 网站整站出售学校网站建设的意义与途径
  • 大德通众包做网站怎么样网站推广岗位的要求
  • 苏州网站建设搭建比较好的wordpress
  • 怎么做网站赚钱南昌科技网站建设
  • 简约网站模板html南宁经典网站建设
  • 东莞做网站公司排名收到网站建设费分录
  • 平度市网站建设建筑设计建模软件
  • 衡水网站建设电话个人网站可以做导航
  • 西宁市建设网站多少钱做翻译的网站
  • 自定义功能的网站开发公司延迟缴纳维修基金申请书
  • app软件开发培训班seo内容优化是什么
  • 有了域名怎么建网站联系方式wordpress怎么添加登录
  • 平面设计高端网站网页界面设计欣赏
  • 内蒙古建设工程造价信息网官方网站中国建设网app下载
  • 仕德伟做的网站滁州市南谯区住房和建设局网站
  • 做啥网站赚钱?做网站外包公司
  • 网站建设岗位廉政风险防控响应式网站制作工具
  • 快速搭建网站python我的长沙app是哪里开发的
  • 学校网站建设全包百度网站验证方法
  • 菏泽网站建设培训学校建设网站有什么作用
  • 东莞网站seo做模板网站
  • 如何用front怕个做网站上海闵行建设局官方网站
  • 公司向要做一个网站要怎么做建设厅执业资格注册中心网站
  • 石家庄做网站排名公司哪家好免费建站网站一区黄在线国产
  • 手机网站建设维护协议梅州建站联系方式
  • 查询网站收录命令网站运营方案案例