成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

怎么在Java中對TreeSet進行自定義類型的排序-創(chuàng)新互聯

怎么在Java中對TreeSet進行自定義類型的排序?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

目前創(chuàng)新互聯已為超過千家的企業(yè)提供了網站建設、域名、網頁空間、成都網站托管、企業(yè)網站設計、游仙網站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

Java可以用來干什么

Java主要應用于:1. web開發(fā);2. Android開發(fā);3. 客戶端開發(fā);4. 網頁開發(fā);5. 企業(yè)級應用開發(fā);6. Java大數據開發(fā);7.游戲開發(fā)等。

TreeSet與Java自定義類型的排序


  • 演示TreeSet對String是可排序的

  • TreeSet無法對自定義類型進行排序

  • 比較規(guī)則怎么寫

  • 自平衡二叉樹結構

  • 實現比較器接口

  • Collections工具類

演示TreeSet對String是可排序的


1.TreeMap集合底層實際上是一個TreeMap
2.TreeMap集合底層是一個二叉樹
3.放到TreeSet集合中的元素,等同于放到TreeMap集合key部分了
4.TreeSet集合中的元素,無序不可重復,但是可以按照元素的大小順序自動排序

稱為:可排序集合
例如:編寫程序從數據庫中取出數據,在頁面展示用戶信息的時候按照生日升序或者降序,
這個時候可以使用TreeSet集合,因為TreeSet集合放進去,拿出來就是有序的。

//創(chuàng)建一個TreeSet集合
  TreeSet<String> ts=new TreeSet<>();
  //添加Stringts.add("zhangsan");ts.add("lisi");ts.add("wangwu");ts.add("zhangsi");ts.add("wangliu");for(String s:ts){
      //按照字典順序排序
      System.out.print(s+" ");
  }
  TreeSet<Integer> ts2=new TreeSet<>();ts2.add(100);ts2.add(200);ts2.add(900);ts2.add(800);  ts2.add(600);ts2.add(10);for(Integer i:ts2){
      //按照升序排序
      System.out.print(i+" ");}

怎么在Java中對TreeSet進行自定義類型的排序

TreeSet無法對自定義類型進行排序

TreeSet可以對自定義類型進行排序?
以下程序中,對于Person類來說,無法排序,因為沒有指定Person對象之間的比較規(guī)則。誰大誰小并沒有說明。

public class TreeSetTest02 {
    public static void main(String[] args) {
        Person p1=new Person(50);
        Person p2=new Person(10);
        Person p3=new Person(20);
        Person p4=new Person(60);
        Person p5=new Person(40);
        Person p6=new Person(30);
        TreeSet<Person> persons=new TreeSet<>();
        persons.add(p1);
        persons.add(p2);
        persons.add(p3);
        persons.add(p4);
        persons.add(p5);
        persons.add(p6);
        for(Person p:persons){
            System.out.println(p);
        }
    }}class Person{
    int age;
    public Person(int age){
        this.age=age;
    }
    @Override
    public String toString() {
        return "Person [age=" + age + "]";
    }}
Exception in thread "main" java.lang.ClassCastException: testCollection.Person cannot be cast to java.lang.Comparable

出現這個錯誤的原因是
Person類沒有實現java.lang,Comparable接口

//放在TreeSet集合中的元素需要實現java.lang.Comparable接口
//并且實現compareTo方法,equals可以不寫

  public class TreeSetTest04 {
        public static void main(String[] args) {
            Customer p1=new Customer(50);
            Customer p2=new Customer(10);
            Customer p3=new Customer(20);
            Customer p4=new Customer(60);
            Customer p5=new Customer(40);
            Customer p6=new Customer(30);
            TreeSet<Customer> customers=new TreeSet<>();
            customers.add(p1);
            customers.add(p2);
            customers.add(p3);
            customers.add(p4);
            customers.add(p5);
            customers.add(p6);
            for(Customer p:customers){
                System.out.println(p);
            }
        }
    }
    //放在TreeSet集合中的元素需要實現java.lang.Comparable接口//并且實現compareTo方法,equals可以不寫
    class Customer implements Comparable<Customer>{
        int age;
        public Customer(int age){
            this.age=age;
        }
        @Override
        public String toString() {
            return "Customer [age=" + age + "]";
        }
        //需要在這個方法中編寫比較的邏輯,或者說比較的規(guī)則,按照什么進行比較。
        //k.compareTo(t.key)
        //拿著參數k和集合中的每個k進行比較,返回值可能是>0,<0,=0
        //比較規(guī)則最終還是程序員實現的:例如按照年齡升序,或者按照年齡降序
        @Override
        public int compareTo(Customer c) {    //c1.compareTo(c2)// TODO Auto-generated method stub
            //this是c1
            //c是c2
            //c1和c2進行比較的時候,就是this和c比較//    int age1=this.age;//    int age2=c.age;//    if(age1==age2){//       return 0;//    }else if(age1>age2){//       return 1;//    }else{//       return -1;//    }
            return this.age-c.age;    //>,<,=
        }

    }

//需要在這個方法中編寫比較的邏輯,或者說比較的規(guī)則,按照什么進行比較。
//k.compareTo(t.key)
//拿著參數k和集合中的每個k進行比較,返回值可能是>0,<0,=0
//比較規(guī)則最終還是程序員實現的:例如按照年齡升序,或者按照年齡降序

比較規(guī)則怎么寫

先按照年齡升序,如果年齡一樣的再按照姓名升序

public class TreeSetTest05 {
    public static void main(String[] args) {
        TreeSet<Vip> vips=new TreeSet<>();
        vips.add(new Vip("zhangsi",20));
        vips.add(new Vip("zhangsan",20));
        vips.add(new Vip("king",18));
        vips.add(new Vip("soft",17));
        for(Vip vip:vips){
            System.out.println(vip);
        }
    }}class Vip implements Comparable<Vip>{
    String name;
    int age;
    public Vip(String name,int age){
        this.name=name;
        this.age=age;
    }
    @Override
    public String toString() {
        return "Vip [name=" + name + ", age=" + age + "]";
    }
    //compareTo方法的返回值很重要:
    //返回0表示相同,value會覆蓋
    //>0,會繼續(xù)在右子樹上找
    //<0,會繼續(xù)在左子樹上找

    @Override
    public int compareTo(Vip v) {
        if(this.age==v.age){
            //年齡相同時,按照名字排序
            //姓名是String類型,可以直接比,調用compareTo方法
            return this.name.compareTo(v.name);
        }else{
            //年齡不一樣
            return this.age-v.age;
        }
    }}

自平衡二叉樹結構

1.自平衡二叉樹,遵循左小右大的原則存放
2.遍歷二叉樹的時候有三種方式
前序遍歷:根左右
中序遍歷:左根右
后序遍歷:左右根
注意:前中后說的是根的位置
3.TreeSet集合和TreeMap集合采用的是中序遍歷方式,即左根右。他們是自平衡二叉樹
100 200 50 60 80 120 140 130 135 180 666

實現比較器接口

TreeSet集合中元素可排序的第二種方式,使用比較器的方式

public class TreeSetTest06 {
    public static void main(String[] args) {
        //創(chuàng)建TreeSet集合的時候,需要使用比較器
        //TreeSet<Wugui> wuGuis=new TreeSet<>();   //這樣不行,沒有通過構造方法傳遞一個比較器進去
        TreeSet<Wugui> wuGuis=new TreeSet<>(new WuguiComparator());
        wuGuis.add(new Wugui(1000));
        wuGuis.add(new Wugui(800));
        wuGuis.add(new Wugui(900));
        wuGuis.add(new Wugui(300));
        wuGuis.add(new Wugui(60));
        for(Wugui wugui:wuGuis){
            System.out.println(wugui);
        }

    }}class Wugui{
    int age;

    public Wugui(int age) {
        super();
        this.age = age;
    }

    @Override
    public String toString() {
        return "Wugui [age=" + age + "]";
    }}//單獨再這里編寫一個比較器//比較器實現java.util.Comparator接口(Comparable是java.lang包下的)class WuguiComparator implements Comparator<Wugui>{
    public int compare(Wugui o1,Wugui o2){
        //指定比較規(guī)則
        //按照年齡排序
        return o1.age-o2.age;
    }}

怎么在Java中對TreeSet進行自定義類型的排序
我們可以使用匿名內部類的方式
可以使用匿名內部類的方式(這個類沒有名字,直接new接口)

TreeSet<Wugui> wuGuis=new TreeSet<>(new Comparator<Wugui>(){public int compare(Wugui o1,Wugui o2){
        //指定比較規(guī)則
        //按照年齡排序
        return o1.age-o2.age;
        }});

最終的結論,放在TreeSet或者TreeMap集合key部分的元素要想做到排序,包括兩種方式
第一種:放在集合中的元素實現java.lang.Comparable接口
第二種:在構造TreeSet或者TreeMap集合的時候給它傳一個比較器對象。

Comparable和Comparator怎么選擇呢?
當比較規(guī)則不會發(fā)生改變的時候,或者說當比較規(guī)則只有1個的時候,建議實現Comparable接口
如果比較規(guī)則有多個,并且需要多個比較規(guī)則之間頻繁切換,建議使用comparator接口
comparator接口的設計符合OCP原則。

Collections工具類

java.util.Collections集合工具類,方便集合的操作

public class CollectionsTest {
    static class Wugui2 implements Comparable<Wugui2>{
        int age;

        public Wugui2(int age) {
            super();
            this.age = age;
        }

        @Override
        public String toString() {
            return "Wugui2 [age=" + age + "]";
        }

        @Override
        public int compareTo(Wugui2 o) {
            // TODO Auto-generated method stub
            return this.age-o.age;
        }
    }
    public static void main(String[] args) {
        //ArrayList集合不是線程安全的
        List<String> list=new ArrayList<String>();
        //變成線程安全的
        Collections.synchronizedList(list);
        //排序
        list.add("abc");
        list.add("abe");
        list.add("abd");
        list.add("abf");
        list.add("abn");
        list.add("abm");
        Collections.sort(list);
        for(String s:list){
            System.out.println(s);
        }
        List<Wugui2> wuguis=new ArrayList<>();
        wuguis.add(new Wugui2(1000));
        wuguis.add(new Wugui2(8000));
        wuguis.add(new Wugui2(4000));
        wuguis.add(new Wugui2(6000));
        //注意:對list集合中元素排序,需要保證list集合中元素實現了Comparable接口
        Collections.sort(wuguis);
        for(Wugui2 wugui:wuguis){
            System.out.println(wugui);
        }
        //對set集合怎么排序呢
        Set<String> set=new HashSet<>();
        set.add("king");
        set.add("kingsoft");
        set.add("king2");
        set.add("king1");
        //將set集合轉換成list集合
        List<String> myList=new ArrayList<>(set);
        Collections.sort(myList);
        for(String s:myList){
            System.out.println(s);
        }
        //這種方式也可以排序
        //Collections.sort(list集合,比較器對象)
    }}

怎么在Java中對TreeSet進行自定義類型的排序


看完上述內容,你們掌握怎么在Java中對TreeSet進行自定義類型的排序的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注創(chuàng)新互聯行業(yè)資訊頻道,感謝各位的閱讀!

新聞標題:怎么在Java中對TreeSet進行自定義類型的排序-創(chuàng)新互聯
當前鏈接:http://jinyejixie.com/article28/csdccp.html

成都網站建設公司_創(chuàng)新互聯,為您提供動態(tài)網站、移動網站建設、域名注冊、網站改版、App開發(fā)建站公司

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

商城網站建設
封开县| 丹江口市| 辽宁省| 江达县| 乌审旗| 政和县| 林甸县| 枝江市| 江北区| 定兴县| 嘉祥县| 珠海市| 巫溪县| 洛扎县| 泌阳县| 潢川县| 庆安县| 蒙自县| 天门市| 林甸县| 临沧市| 乌海市| 布尔津县| 乐亭县| 秦皇岛市| 马龙县| 上高县| 望谟县| 长宁区| 宜丰县| 阳江市| 肃宁县| 瓦房店市| 六枝特区| 安图县| 仪征市| 长春市| 布尔津县| 芷江| 民和| 丰原市|