二叉樹實(shí)現(xiàn)排序列表

使用Java實(shí)現(xiàn)的二叉樹排序列表

  • 二叉樹實(shí)現(xiàn)類
package binarytree.create;
/**
 *  二叉樹的實(shí)現(xiàn)類
 * @param <T>
 */
public class BinaryTree<T extends Comparable<T>> {

    private class Node {
        private Comparable<T> data;
        private Node parent; // 父節(jié)點(diǎn)
        private Node left; // 左子樹
        private Node right; // 右子樹
        
        Node(Comparable<T> data){
            this.data = data;
        }

        /**
         * 添加節(jié)點(diǎn)
         * @param node
         */
        public void addNode(Node node) {
            if (node.data.compareTo((T) this.data) <= 0) { // 要加入當(dāng)前節(jié)點(diǎn)的節(jié)點(diǎn),比當(dāng)前節(jié)點(diǎn)要小
                if (this.left == null) {
                    this.left = node; // 當(dāng)前節(jié)點(diǎn)的左節(jié)點(diǎn)不存在,加入左節(jié)點(diǎn)
                    node.parent = this; // 保存父節(jié)點(diǎn)
                } else {
                    this.left.addNode(node); // 當(dāng)前節(jié)點(diǎn)的左節(jié)點(diǎn)已經(jīng)存在缺亮,繼續(xù)向下做判斷
                }
            } else { // 要加入當(dāng)前節(jié)點(diǎn)的節(jié)點(diǎn),比當(dāng)前節(jié)點(diǎn)大
                if (this.right == null) {
                    this.right = node; // 加入當(dāng)前節(jié)點(diǎn)的右節(jié)點(diǎn)
                    node.parent = this; // 保存父節(jié)點(diǎn)
                } else {
                    this.right.addNode(node); // 當(dāng)前節(jié)點(diǎn)的右節(jié)點(diǎn)已存在劫侧,繼續(xù)向下做判斷
                }
            }
        }

        /**
         * 實(shí)現(xiàn)所有數(shù)據(jù)的獲取處理,按照中序遍歷的處理(按照二叉樹的分布烧栋,左子樹<根節(jié)點(diǎn)<右子樹写妥,由小到大的排序獲取)
         */
        public void toArrayNode() {
            if (this.left != null) {
                this.left.toArrayNode(); // 遞歸調(diào)用獲取值
            }
            BinaryTree.this.returnData[BinaryTree.this.foot++] = this.data;
            if (this.right != null) {
                this.right.toArrayNode();
            }
        }
    }

    // ----------------------- 以下為二叉樹的實(shí)現(xiàn) -----------------------
    // 根節(jié)點(diǎn)
    private Node root;
    // 統(tǒng)計(jì)節(jié)點(diǎn)個(gè)數(shù)
    private int count;
    // 腳標(biāo)
    private int foot;
    // 返回?cái)?shù)據(jù)
    private Object[] returnData;

    /**
     * @NullPointerException 當(dāng)傳入的數(shù)據(jù)對(duì)象為null時(shí)拋出空指針異常
     * @param data
     */
    public void add(Comparable<T> data) {
        if (data == null) {
            throw new NullPointerException("添加的數(shù)據(jù)為空");
        } else {
            Node newNode = new Node(data);
            if (root == null) {
                root = newNode;
            } else { // 加入一個(gè)合適的節(jié)點(diǎn)
                root.addNode(newNode);
            }
        }
        this.count++;
    }

    /**
     * 獲取返回值
     *  如果當(dāng)前的二叉樹長度為0珍特,直接返回null
     * @return
     */
    public Object[] returnArrayData(){
        if (this.count == 0) {
            return null;
        }
        returnData = new Object[this.count]; // 有多少個(gè)節(jié)點(diǎn)就創(chuàng)建多少個(gè)長度的對(duì)象
        this.root.toArrayNode(); // 直接通過Node類負(fù)責(zé)
        this.foot = 0; // 腳標(biāo)清0
        return this.returnData;
    }
}
  • 實(shí)體類
package binarytree.create.entity;

public class Person implements Comparable<Person> {

    private String name;
    private Integer age;
    public Person(String name, Integer age) {
        this.name = name;
        this.age = age;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public Integer getAge() {
        return age;
    }
    public void setAge(Integer age) {
        this.age = age;
    }
    @Override
    public int compareTo(Person o) {
        return this.age - o.age; // 當(dāng)前對(duì)象大于比較對(duì)象時(shí)為1邑跪,當(dāng)前對(duì)象小于比較對(duì)象為負(fù)數(shù),相等為0(正序排序)
    }
    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}
  • 測(cè)試類
package binarytree.create;
import binarytree.create.entity.Person;
import java.util.Arrays;

public class BinaryTreeTest{
    public static void main(String[] args) {
        BinaryTree<Person> tree = new BinaryTree<Person>();
        tree.add(new Person("張三",20));
        tree.add(new Person("李四",10));
        tree.add(new Person("王五",50));
        tree.add(new Person("趙六",30));
        System.out.println(Arrays.toString(tree.returnArrayData()));
    }
}
  • 輸出結(jié)果

[Person{name='李四', age=10}, Person{name='張三', age=20}, Person{name='小趙', age=30}, Person{name='王五', age=50}]

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末砸琅,一起剝皮案震驚了整個(gè)濱河市轴踱,隨后出現(xiàn)的幾起案子症脂,更是在濱河造成了極大的恐慌淫僻,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件雳灵,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡悯辙,警方通過查閱死者的電腦和手機(jī)迎吵,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來击费,“玉大人,你說我怎么就攤上這事桦他。” “怎么了快压?”我有些...
    開封第一講書人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵,是天一觀的道長嗓节。 經(jīng)常有香客問我荧缘,道長拦宣,這世上最難降的妖魔是什么信姓? 我笑而不...
    開封第一講書人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮意推,結(jié)果婚禮上豆瘫,老公的妹妹穿的比我還像新娘。我一直安慰自己菊值,他們只是感情好外驱,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著腻窒,像睡著了一般昵宇。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上儿子,一...
    開封第一講書人閱讀 52,457評(píng)論 1 311
  • 那天瓦哎,我揣著相機(jī)與錄音,去河邊找鬼柔逼。 笑死蒋譬,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的愉适。 我是一名探鬼主播犯助,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼维咸!你這毒婦竟也來了剂买?” 一聲冷哼從身側(cè)響起惠爽,我...
    開封第一講書人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎雷恃,沒想到半個(gè)月后疆股,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡倒槐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年旬痹,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片讨越。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡两残,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出把跨,到底是詐尸還是另有隱情人弓,我是刑警寧澤,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布着逐,位于F島的核電站崔赌,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏耸别。R本人自食惡果不足惜健芭,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望秀姐。 院中可真熱鬧慈迈,春花似錦、人聲如沸省有。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蠢沿。三九已至伸头,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間搏予,已是汗流浹背熊锭。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來泰國打工碗殷, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留速缨,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓仿粹,卻偏偏與公主長得像搁吓,于是被迫代替她去往敵國和親堕仔。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

推薦閱讀更多精彩內(nèi)容

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法朗若,內(nèi)部類的語法,繼承相關(guān)的語法哭懈,異常的語法,線程的語...
    子非魚_t_閱讀 31,664評(píng)論 18 399
  • 一. Java基礎(chǔ)部分.................................................
    wy_sure閱讀 3,814評(píng)論 0 11
  • 我是從西安到上海去的睬罗,但卻不是西安人旭斥,而是四川人。2000年3月琉预,開始了滬漂蒿褂。 去上海的原因是帶我的導(dǎo)師落葉歸根,...
    拓拔濯閱讀 358評(píng)論 0 0
  • 特意娄帖,爬到超市昙楚,走了一道,旁邊都是微雪化后濕漉漉的馬路堪旧,狗狗歡快的往前奔跑,以為是按常態(tài)溜達(dá)它去淳梦,其實(shí)是隨便溜達(dá)它...
    三三蝸牛閱讀 423評(píng)論 0 1
  • 你想過普通的生活作郭,就會(huì)遇到普通的挫折夹攒。你想過上最好的生活,就一定會(huì)遇上最強(qiáng)的傷害咏尝。這世界很公平,你想要最好状土,就一定...
    永遠(yuǎn)的橋_cfc4閱讀 217評(píng)論 1 9