Treeset之自然排序

1.Treeset中的集合石有序的,(有序即是按照大小寫排序),是用二叉樹實現的.
2.明白二叉樹的數據結構.
遍歷的時候 前序: 中左右
中序: 左中右
后序: 左右中
3.TreeSet 是 無序 不允許重復的,無序: 是展示順序與存入順序不同
但是是可排序的,是可以按照大小順序排列的
4.排序可分為:自然排序 1234 abcdef 包括自定義的類
定制排序 1234 abcdef 包括自定義的類

題目要求:有很多人 :

  • 每一個人 有一本書
  • 先按照 人的 年齡降序排序
  • 按照 人的姓名升序排序
  • 按照書的價格降序排序
  • 按照書的 書名升序排序

首先看自然排序:
Person類中有name age book對象屬性.Person類要實現Comparable接口,后面<>里面就寫Person類.另外要注意,Person類要重寫compareTo()方法.在此方法里面,如果比較帶有漢字的字符串的值,不能直接用String進行比較.這就要求先創建一個Colator對象,這個對象進行調用getColllationKey("漢字") 來創建一個CollationKey對象.
CollationKey對象調用compareTo方法可以返回比較值.即num,看代碼:

        Collator collator = Collator.getInstance();
        CollationKey key = collator.getCollationKey(this.name);
        CollationKey key2 = collator.getCollationKey(o.name);
        int num = key.compareTo(key2);

另外,在姓名相同比較書的屬性值得時候,會有一個低耦合,高內聚的知識點.
1.耦合性:也稱塊間聯系。指軟件系統結構中各模塊間相互聯系緊密程度的一種度量。模塊之間聯系越緊密,其耦合性就越強,模塊的獨立性則越差。模塊間耦合高低取決于模塊間接口的復雜性、調用的方式及傳遞的信息.
2.內聚性:又稱塊內聯系。指模塊的功能強度的度量,即一個模塊內部各個元素彼此結合的緊密程度的度量。若一個模塊內各元素(語名之間、程序段之間)聯系的越緊密,則它的內聚性就越高。
所以,如果把比較書的屬性值最好放在其本類進行比較,為的是如果修改某屬性名或者方法名,牽扯到的一些需要修改的地方就只是在本類修改.在Book類中,因為要比較書的屬性值,所以要實現Comparable接口,在重寫的compareTo()方法中進行比較.

package com.qf.demo6;
// 低耦合  高內聚
import java.text.CollationKey;
import java.text.Collator;

public class Person implements Comparable<Person>{

    private String name;
    private int age;
    private  Book book;
    public Person(String name, int age, Book book) {
        super();
        this.name = name;
        this.age = age;
        this.book = book;
    }
    public Person() {
        super();
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public Book getBook() {
        return book;
    }
    public void setBook(Book book) {
        this.book = book;
    }
    @Override
    public String toString() {
        return "Person [name=" + name + ", age=" + age + ", book=" + book + "]";
    }
    
    @Override
    //按照年齡 降序
    public int compareTo(Person o) {
        if(this.age>o.age){
            return -1;
        }else if(this.age<o.age){
            return 1;
        }else {//年齡相同  比較姓名 升序
            // 第二排序
            Collator collator = Collator.getInstance();
            CollationKey key = collator.getCollationKey(this.name);
            CollationKey key2 = collator.getCollationKey(o.name);
            int num = key.compareTo(key2);
            if(num>0){
                return 1;
            }else if(num<0){
                return -1;
            }else {//姓名相同 比較書的一些屬性值 
                // 第三條件 和第四條件
                return this.book.compareTo(o.book);
            }
        }
    }
}

  package com.qf.demo6;

import java.text.CollationKey;
import java.text.Collator;

public class Book implements Comparable<Book>{

    private String bookName;
    private int price;
    public Book(String bookName, int price) {
        super();
        this.bookName = bookName;
        this.price = price;
    }
    public Book() {
        super();
    }
    public String getBookName() {
        return bookName;
    }
    public void setBookName(String bookName) {
        this.bookName = bookName;
    }
    public int getPrice() {
        return price;
    }
    public void setPrice(int price) {
        this.price = price;
    }
    @Override
    public String toString() {
        return "Book [bookName=" + bookName + ", price=" + price + "]";
    }
    @Override
    public int compareTo(Book o) {
        // 第三條件  降序
        if(this.getPrice()>o.getPrice()){
            return -1;
        }else if(this.getPrice()< o.getPrice()){
            return 1;
        }else{
            // 第四條件  升序
            Collator collator2 = Collator.getInstance();
            CollationKey key3 = collator2.getCollationKey(this.getBookName());
            CollationKey key4 = collator2.getCollationKey(o.getBookName());
            int num1 = key3.compareTo(key4);
            return num1;
        }
    }
    
    
}

// 如果this.age大于o.age   返回1的話  就是把this對象往后放,即是升序.
 if(this.age>o.age){
            return 1;
        }else if(this.age<o.age){
            return -1;
        }else{
            return 0; 
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,936評論 6 535
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,744評論 3 421
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,879評論 0 381
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,181評論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,935評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,325評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,384評論 3 443
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,534評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,084評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,892評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,067評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,623評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,322評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,735評論 0 27
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,990評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,800評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,084評論 2 375

推薦閱讀更多精彩內容

  • 1. Java基礎部分 基礎部分的順序:基本語法,類相關的語法,內部類的語法,繼承相關的語法,異常的語法,線程的語...
    子非魚_t_閱讀 31,726評論 18 399
  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,799評論 18 139
  • 從三月份找實習到現在,面了一些公司,掛了不少,但最終還是拿到小米、百度、阿里、京東、新浪、CVTE、樂視家的研發崗...
    時芥藍閱讀 42,328評論 11 349
  • (一)Java部分 1、列舉出JAVA中6個比較常用的包【天威誠信面試題】 【參考答案】 java.lang;ja...
    獨云閱讀 7,130評論 0 62
  • 解放村樂隊隊長的《28/一間房里最少需要幾件家具?》里面提到: 梭羅在《瓦爾登湖》里曾經談到過一個有趣的話題,一間...
    苦寂生閱讀 300評論 2 3