Treeset之自然排序

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

題目要求:有很多人 :

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

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

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

另外,在姓名相同比較書的屬性值得時候,會有一個低耦合,高內(nèi)聚的知識點.
1.耦合性:也稱塊間聯(lián)系吩蔑。指軟件系統(tǒng)結(jié)構(gòu)中各模塊間相互聯(lián)系緊密程度的一種度量。模塊之間聯(lián)系越緊密蔚万,其耦合性就越強珠插,模塊的獨立性則越差闸准。模塊間耦合高低取決于模塊間接口的復(fù)雜性版确、調(diào)用的方式及傳遞的信息.
2.內(nèi)聚性:又稱塊內(nèi)聯(lián)系。指模塊的功能強度的度量尚洽,即一個模塊內(nèi)部各個元素彼此結(jié)合的緊密程度的度量悔橄。若一個模塊內(nèi)各元素(語名之間、程序段之間)聯(lián)系的越緊密腺毫,則它的內(nèi)聚性就越高癣疟。
所以,如果把比較書的屬性值最好放在其本類進行比較,為的是如果修改某屬性名或者方法名,牽扯到的一些需要修改的地方就只是在本類修改.在Book類中,因為要比較書的屬性值,所以要實現(xiàn)Comparable接口,在重寫的compareTo()方法中進行比較.

package com.qf.demo6;
// 低耦合  高內(nèi)聚
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; 
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市潮酒,隨后出現(xiàn)的幾起案子争舞,更是在濱河造成了極大的恐慌,老刑警劉巖澈灼,帶你破解...
    沈念sama閱讀 222,590評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件竞川,死亡現(xiàn)場離奇詭異,居然都是意外死亡叁熔,警方通過查閱死者的電腦和手機委乌,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,157評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來荣回,“玉大人遭贸,你說我怎么就攤上這事⌒娜恚” “怎么了壕吹?”我有些...
    開封第一講書人閱讀 169,301評論 0 362
  • 文/不壞的土叔 我叫張陵著蛙,是天一觀的道長。 經(jīng)常有香客問我耳贬,道長踏堡,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,078評論 1 300
  • 正文 為了忘掉前任咒劲,我火速辦了婚禮顷蟆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘腐魂。我一直安慰自己帐偎,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 69,082評論 6 398
  • 文/花漫 我一把揭開白布蛔屹。 她就那樣靜靜地躺著削樊,像睡著了一般。 火紅的嫁衣襯著肌膚如雪兔毒。 梳的紋絲不亂的頭發(fā)上嫉父,一...
    開封第一講書人閱讀 52,682評論 1 312
  • 那天,我揣著相機與錄音眼刃,去河邊找鬼。 笑死摇肌,一個胖子當(dāng)著我的面吹牛擂红,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播围小,決...
    沈念sama閱讀 41,155評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼昵骤,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了肯适?” 一聲冷哼從身側(cè)響起变秦,我...
    開封第一講書人閱讀 40,098評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎框舔,沒想到半個月后蹦玫,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,638評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡刘绣,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,701評論 3 342
  • 正文 我和宋清朗相戀三年樱溉,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片纬凤。...
    茶點故事閱讀 40,852評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡福贞,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出停士,到底是詐尸還是另有隱情挖帘,我是刑警寧澤完丽,帶...
    沈念sama閱讀 36,520評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站拇舀,受9級特大地震影響逻族,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜你稚,卻給世界環(huán)境...
    茶點故事閱讀 42,181評論 3 335
  • 文/蒙蒙 一瓷耙、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧刁赖,春花似錦搁痛、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,674評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至枪芒,卻和暖如春彻况,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背舅踪。 一陣腳步聲響...
    開封第一講書人閱讀 33,788評論 1 274
  • 我被黑心中介騙來泰國打工纽甘, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人抽碌。 一個月前我還...
    沈念sama閱讀 49,279評論 3 379
  • 正文 我出身青樓悍赢,卻偏偏與公主長得像,于是被迫代替她去往敵國和親货徙。 傳聞我的和親對象是個殘疾皇子左权,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,851評論 2 361

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

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法痴颊,內(nèi)部類的語法赏迟,繼承相關(guān)的語法,異常的語法蠢棱,線程的語...
    子非魚_t_閱讀 31,665評論 18 399
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理锌杀,服務(wù)發(fā)現(xiàn),斷路器泻仙,智...
    卡卡羅2017閱讀 134,715評論 18 139
  • 從三月份找實習(xí)到現(xiàn)在抛丽,面了一些公司,掛了不少饰豺,但最終還是拿到小米亿鲜、百度、阿里、京東蒿柳、新浪饶套、CVTE、樂視家的研發(fā)崗...
    時芥藍(lán)閱讀 42,278評論 11 349
  • (一)Java部分 1垒探、列舉出JAVA中6個比較常用的包【天威誠信面試題】 【參考答案】 java.lang;ja...
    獨云閱讀 7,118評論 0 62
  • 解放村樂隊隊長的《28/一間房里最少需要幾件家具妓蛮?》里面提到: 梭羅在《瓦爾登湖》里曾經(jīng)談到過一個有趣的話題,一間...
    苦寂生閱讀 294評論 2 3