树——平衡二叉树插入和查找的JAVA实现

package com.tomsnail.data.tree;
/*** AVL二叉平衡树* @author tomsnail* @date 2015年3月30日 下午4:35:50*/
public class AVLTree {/*** 根节点* @author tomsnail* @date 2015年3月30日 下午4:36:54*/private AVLNode rootNode;private String bulidType = "";/*** 增加一个节点* @author tomsnail* @date 2015年3月30日 下午4:36:08*/public void add(int value){AVLNode subNode = null;if(rootNode==null){subNode  = new AVLNode(value);rootNode = subNode;}else{            subNode = addNode(rootNode,value);}reBuild(subNode);}private AVLNode addNode(AVLNode node,int value){AVLNode subNode = null;if(node.getValue()>value){if(node.getLeftNode()==null){subNode = new AVLNode(value);node.setLeftNode(subNode);}else{subNode = addNode(node.getLeftNode(), value);}}if(node.getValue()<value){if(node.getRightNode()==null){subNode = new AVLNode(value);node.setRightNode(subNode);}else{subNode = addNode(node.getRightNode(),value);}}return subNode;}/*** 重平衡树* @author tomsnail* @date 2015年3月30日 下午5:42:00*/private void reBuild(AVLNode node){if(node!=null){AVLNode tempRootNode = findTempRootNode(node);if(tempRootNode!=null){if(bulidType.equals("ll")){Lrotate(node,tempRootNode);}else if(bulidType.equals("rr")){Rrotate(node,tempRootNode);}else if(bulidType.equals("lr")){Rrotate(node,tempRootNode.getLeftNode());Lrotate(node,tempRootNode);}else if(bulidType.equals("rl")){Lrotate(node,tempRootNode.getRightNode());Rrotate(node,tempRootNode);}}}}/*** 左旋* @author tomsnail* @date 2015年3月30日 下午9:23:28*/private void Rrotate(AVLNode node,AVLNode tempRootNode){AVLNode rotateNode = tempRootNode.getRightNode();AVLNode rootNode = tempRootNode.getRootNode();String type = "";if(rootNode!=null){if(rootNode.getLeftNode()==tempRootNode){type="l";}else{type="r";}}AVLNode adjustNode = rotateNode.getLeftNode();rotateNode.setLeftNode(tempRootNode);tempRootNode.setRightNode(null);if(adjustNode!=null){tempRootNode.setRightNode(adjustNode);}if(rootNode==null){rotateNode.setRootNode(null);this.rootNode = rotateNode;}if(type.equals("r")){rootNode.setRightNode(rotateNode);}else if(type.equals("l")){rootNode.setLeftNode(rotateNode);}}/*** 右旋* @author tomsnail* @date 2015年3月30日 下午9:23:28*/private void Lrotate(AVLNode node,AVLNode tempRootNode){AVLNode rotateNode = tempRootNode.getLeftNode();AVLNode rootNode = tempRootNode.getRootNode();String type = "";if(rootNode!=null){if(rootNode.getLeftNode()==tempRootNode){type="l";}else{type="r";}}AVLNode adjustNode = rotateNode.getRightNode();rotateNode.setRightNode(tempRootNode);tempRootNode.setLeftNode(null);if(adjustNode!=null){tempRootNode.setLeftNode(adjustNode);}if(rootNode==null){rotateNode.setRootNode(null);this.rootNode = rotateNode;}if(type.equals("r")){rootNode.setRightNode(rotateNode);}else if(type.equals("l")){rootNode.setLeftNode(rotateNode);}}/*** 查找最小不平衡的根节点* @author tomsnail* @date 2015年3月30日 下午5:40:55*/private AVLNode findTempRootNode(AVLNode node){AVLNode noB = getNoBalance(node);if(noB==null){return null;}if(isTypeLL(noB)){bulidType = "ll";}else if(isTypeRR(noB)){bulidType = "rr";}else if(isTypeLR(noB)){bulidType = "lr";}else if(isTypeRL(noB)){bulidType = "rl";}return noB;}private boolean isTypeLL(AVLNode noB){try {if(noB.getRightNode()==null&&noB.getLeftNode().getRightNode()==null&&!noB.getLeftNode().getLeftNode().hasSubNode()){return true;}if(noB.getRightNode()!=null&&noB.getLeftNode().getRightNode()!=null&&noB.getLeftNode().getLeftNode().hasSubNode()){return true;}} catch (Exception e) {}return false;}private boolean isTypeRR(AVLNode noB){try {if(noB.getLeftNode()==null&&noB.getRightNode().getLeftNode()==null&&!noB.getRightNode().getRightNode().hasSubNode()){return true;}if(noB.getLeftNode()!=null&&noB.getRightNode().getLeftNode()!=null&&noB.getRightNode().getRightNode().hasSubNode()){return true;}} catch (Exception e) {}return false;}private boolean isTypeLR(AVLNode noB){try {if(noB.getRightNode()==null&&noB.getLeftNode().getLeftNode()==null&&!noB.getLeftNode().getRightNode().hasSubNode()){return true;}if(noB.getRightNode()!=null&&noB.getLeftNode().getLeftNode()!=null&&noB.getLeftNode().getRightNode().hasSubNode()){return true;}} catch (Exception e) {}return false;}private boolean isTypeRL(AVLNode noB){try {if(noB.getLeftNode()==null&&noB.getRightNode().getRightNode()==null&&!noB.getRightNode().getLeftNode().hasSubNode()){return true;}if(noB.getLeftNode()!=null&&noB.getRightNode().getRightNode()!=null&&noB.getRightNode().getLeftNode().hasSubNode()){return true;}} catch (Exception e) {}return false;}private AVLNode getNoBalance(AVLNode node){if(node.getRootNode()==null){return null;}else{if(!isBalance(node.getRootNode())){return node.getRootNode();}else{return getNoBalance(node.getRootNode());}}}/*** 查找一个节点* @author tomsnail* @date 2015年3月30日 下午4:36:35*/public AVLNode find(int value){return findWith2(rootNode,value);}private AVLNode findWith2(AVLNode node,int value){if(node==null){return null;}System.out.println(node.getValue());if(node.getValue()>value){return findWith2(node.getLeftNode(),value);}else if(node.getValue()<value){return findWith2(node.getRightNode(),value);}else{return node;}}public void midScan(AVLNode node){if(node==null){return;}midScan(node.getLeftNode());System.out.println(node.getValue());midScan(node.getRightNode());}public AVLNode getRootNode() {return rootNode;}public static void main(String[] args) {int[] is = new int[]{10,11,23,3,5,44,32,4,6,18,19,7,8,70,50,60,40,55,65,53,80};//10,11,23,3,5,44,32,4,6,18,19,7,8,70,50,60,40,55,65,53,80AVLTree tree = new AVLTree();for(int i=0;i<is.length;i++){tree.add(is[i]);}System.out.println(tree.getRootNode().getValue());System.out.println("----------------------------");tree.midScan(tree.getRootNode());System.out.println(isBalance(tree.getRootNode()));}public static int depth(AVLNode node){if(node==null){return 0;}else{        int ld = depth(node.getLeftNode());        int rd = depth(node.getRightNode());        return 1 + (ld >rd ? ld : rd);    }}public static boolean isBalance(AVLNode node){    if (node==null)         return true;    int dis = depth(node.getLeftNode()) - depth(node.getRightNode());    if (dis>1 || dis<-1 )        return false;    else        return isBalance(node.getLeftNode()) && isBalance(node.getRightNode());}
}class AVLNode{private int value;private AVLNode leftNode;private AVLNode rightNode;private AVLNode rootNode;public int getValue() {return value;}public void setValue(int value) {this.value = value;}public AVLNode getLeftNode() {return leftNode;}public void setLeftNode(AVLNode leftNode) {this.leftNode = leftNode;if(leftNode!=null){leftNode.setRootNode(this);}}public AVLNode getRightNode() {return rightNode;}public void setRightNode(AVLNode rightNode) {this.rightNode = rightNode;if(rightNode!=null){rightNode.setRootNode(this);}}public AVLNode getRootNode() {return rootNode;}public void setRootNode(AVLNode rootNode) {this.rootNode = rootNode;}public boolean hasSubNode(){if(this.leftNode!=null||this.rightNode!=null){return true;}else{return false;}}public AVLNode(){}public AVLNode(int value){this.value = value;}
}

 

转载于:https://www.cnblogs.com/TomSnail/p/4379702.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/359056.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

APP推广工具(总结)

全是干活,懂得人慢慢听我道来。 基于友盟+大数据,如有侵权请告知与我。 一、学习、资讯 1.渠道点评 网址:http://qddp.niaogebiji.com/ 简介:渠道点评是专注于广告、营销、推广商务合作渠道资源点评的综合平台,聚合App推广、信息流广告等众多主流推广渠道广告代理商公…

JUnit:使用Java 8和AssertJ 3.0.0测试异常

Java 8的AssertJ 3.0.0发行版比以前更容易测试异常。 在我以前的一篇博客文章中&#xff0c;我描述了如何利用纯 Java 8实现此目的&#xff0c;但是使用AssertJ 3.0.0可能会删除我创建的许多代码。 警告&#xff1a;此博客文章主要包含代码示例。 SUT –被测系统 我们将测试以…

怎么修改_论文查重之后怎么修改?

使用知网论文查重以后&#xff0c;发现论文重复率很高&#xff0c;该怎么办&#xff1f;论文查重后怎么改&#xff1f;今天paperfree小编给大家介绍一下。方法一&#xff1a;重写如果论文存在很高的重复率&#xff0c;都是抄袭别人的论文&#xff0c;我们就可以考虑重写。在重写…

java枚举使用详解

package com.ljq.test;/** * 枚举用法详解 * * author jiqinlin * */ public class TestEnum { /** * 普通枚举 * * author jiqinlin * */ public enum ColorEnum { red, green, yellow, blue; }/** * 枚举像普通的类一样可以添加属性和方法&#xff0c;可以为它添加静态和非静…

js数组再倒数第二个添加元素_归纳JS中数组的使用(一)元素新增和删除

新增元素js中给数组新增元素主要通过2个方法 push 和 unshiftArray.prototype.push功能概述push() 方法将一个或多个元素添加到数组的末尾&#xff0c;并返回该数组的新长度(该方法修改原有数组)。语法arr.push(element1, ..., elementN)关注点新增的元素出现在数组的末尾可以一…

基于谷歌模型gemini-pro 的开发的QT 对话项目

支持的功能&#xff0c;新建对话框&#xff0c;目前发现相关梯子不支持访问谷歌的api 的可能代理设置的不对&#xff0c; QNetworkAccessManager manager;// Set up your requestQNetworkRequest request;request.setUrl(QUrl("https://generativelanguage.googleapis.com…

PS快速将白底图片变为透明图片的解决办法

公司的公章被傻逼老板带到国外去啦&#xff0c;现在还得用公章&#xff0c;就只能拿以前的文件p图啦。 在将白底图片修改为透明图片时&#xff0c;我首先能想到的是简单的利用磁性套索工具选择图片&#xff08;非常细微的操作&#xff09;&#xff0c;但是一不小心就容易出错&a…

Lucene.net站内搜索—5、搜索引擎第一版实现

目录 Lucene.net站内搜索—1、SEO优化 Lucene.net站内搜索—2、Lucene.Net简介和分词 Lucene.net站内搜索—3、最简单搜索引擎代码Lucene.net站内搜索—4、搜索引擎第一版技术储备&#xff08;简单介绍Log4Net、生产者消费者模式&#xff09;Lucene.net站内搜索—5、搜索引擎第…

java ee jms_Java EE6事件:JMS的轻量级替代品

java ee jms我今天要讨论的功能是Java EE 6中的事件机制。一般的想法是触发一个事件&#xff0c;并让事件监听器来接收它。 我创建了这个完全没有用的示例&#xff0c;但是它的简单性帮助我专注于重要的内容。 我将从后备操作中触发LogEvent&#xff0c;该事件将记录到java.uti…

All your files have been encrypted

小弟的姑姑家的老板收银的电脑被黑客黑了,我来解决一下,小孩玩游戏玩电脑中的病毒, 方法很多种,仅供参考。 问题邮件截图: 参考方式: 方法一:给对方钱,一般比较贵,还不如重装系统。哈哈。 方法二:下载解密工具,尝试解密恢复数据, Ransomware File Decrypto Too…

8s yaml 配置生成_接口测试框架实战(六) | 配置的数据驱动

《Python 测试开发实战进阶》课程&#xff0c;4 个月挑战 BAT 大厂年薪 50W Offer&#xff0c;文末加群&#xff01;在实际工作中&#xff0c;为了便于维护&#xff0c;对于环境的切换和配置&#xff0c;通常不会使用硬编码的形式完成。在之前文章《多环境下的接口测试》中&…

机房合作(一):我怎样做组长(敢于承担责任)

导读&#xff1a;小组合作开始了&#xff0c;不怕死的我&#xff0c;揽下了组长的活儿。然后开始了我的漫漫长征路。不过&#xff0c;不怕猪一样的组长&#xff0c;咱有神一样的组员。机房合作到现在&#xff0c;真的感激组员的配合以及对我这个猪组长的指点。接下来&#xff0…

使用JAXB和Jackson从XSD生成JSON模式

在本文中&#xff0c;我演示了一种从XML Schema &#xff08;XSD&#xff09;生成JSON Schema的 方法 。 在概述从XML Schema创建JSON Schema的方法的同时&#xff0c;本文还演示了JAXB实现的用法&#xff08;与JDK 9捆绑在一起的xjc版本2.2.12-b150331.1824 [build 1.9.0-ea-b…

成功人士都有的好习惯

人们常问的一个问题是:那些成功的人是如何获得成功的。这个问题的众多答案之一可能就隐藏在他们的日常习惯之中——但这些习惯到底是什么,它们与成功又有什么关系呢? 习惯是指以固定的方式定期进行的实践或行为模式。在这种情况下,意味着成功人士必须采取日常实践,才有可…

有多个python版本_python 多版本共存

有时候需要在同一台机器上安装多个版本的python常见的解决方式如下&#xff1a;一、1. 下载python2.7和python3.7&#xff0c;然后在C盘下新建一个Python文件夹&#xff0c;python2.7安装到 C:\Python\Python27python3.7安装到 C:\Python\Python372. 检查 系统变量中是否有…

Spring Integration完整示例

本文是我们名为“ Spring Integration for EAI ”的学院课程的一部分。 在本课程中&#xff0c;向您介绍了企业应用程序集成模式以及Spring Integration如何解决它们。 接下来&#xff0c;您将深入研究Spring Integration的基础知识&#xff0c;例如通道&#xff0c;转换器和适…

为什么要创业

在这个时代,成为一名企业家比以往任何时候都要容易,技术正在缩小世界,打开市场,让许多人在他们梦想的领域中独辟蹊径。 然而,许多拥有好点子的人却害怕采取行动。不要让自己成为那些后悔没有创业的人。如果你想掌控你的生活,实现你的梦想。那么你就有无数的理由创业,我…

heroku_简单的Twitter:Heroku上的Play框架,AJAX,CRUD

heroku因此&#xff0c;重大的公告已经发布– Heroku开始为Play Framework应用程序提供本机支持&#xff01; 如果您还没有听说过&#xff0c;请在Heroku的博客上查看Jesper Joergensen的帖子 。 因此&#xff0c;对于演示&#xff0c;我将建立一个非常基本的Twitter副本&#…

配置环境_JavaJDK环境变量配置

1.Java环境搭建1.1 JDK与JREJDK(Java Development Kit Java开发工具包)JDK是提供给Java开发人员使用的&#xff0c;其中包含了java的开发工具&#xff0c;也包括了JRE。所以安装了JDK&#xff0c;就不用在单独安装JRE了。其中开发工具&#xff1a;编译工具(javac.exe)打包工具(…

僵固式思维 OR 成长式思维

有意无意中&#xff0c;看到这样的一篇文章&#xff0c;觉得非常富有正能量&#xff0c;而且也比较有同感。而且&#xff0c;不仅仅对于职场暂时失落或者失意的人有帮助&#xff0c;就是对学生&#xff0c;也一样的。故特分享&#xff0c;以共勉之。 我想每个新人进入职场之后都…