欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java之TreeSet和TreeMap的兩種排序方式解讀

 更新時(shí)間:2024年08月01日 10:11:36   作者:我是逸杰  
這篇文章主要介紹了Java之TreeSet和TreeMap的兩種排序方式解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

一、TreeSet比較常見形式

TreeSet可以對(duì)元素按照某種規(guī)則進(jìn)行排序:

public class test {
    public static void main(String[] args) {
        Set<Integer> s1=new TreeSet<>();
        s1.add(23);
        s1.add(3);
        s1.add(2);
        s1.add(13);
        s1.add(63);
        s1.add(25);
        s1.add(22);
        System.out.println(s1);
        Set<String> s2=new TreeSet<>();
        s2.add("c");
        s2.add("f");
        s2.add("a");
        s2.add("t");
        s2.add("j");
        s2.add("b");
        s2.add("n");
        System.out.println(s2);
    }
}

如果添加的是對(duì)象(Studen)時(shí),如何排序呢?

class Student{
    private String name;
    private int age;

    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 Student(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public Student() {
    }
}

public class test {
    public static void main(String[] args) {
        Set<Student> s1=new TreeSet<Student>();
        s1.add(new Student("zhangsan",23));
        s1.add(new Student("lisi",22));
        s1.add(new Student("wangwu",32));
        s1.add(new Student("huyijie",19));
        System.out.println("s1===================");
        for(Student s:s1){
            System.out.println(s);
        }
    }

}

會(huì)發(fā)現(xiàn)無法排序。

二、解決方法

1 自然排序

  • TreeSet存入數(shù)據(jù)后自動(dòng)調(diào)用元素的compareTo(Object obj)方法,自動(dòng)對(duì)數(shù)據(jù)進(jìn)行排序,所以輸出的數(shù)據(jù)是經(jīng)過排序的數(shù)據(jù)
  • 注:compareTo方法返回值有:負(fù)數(shù)、零、整數(shù),分別表示小于、等于、大于。
  • 對(duì)于存入自定義的對(duì)象元素時(shí),要重寫元素的compareTo(Object obj)方法
  • 元素定義時(shí),需要實(shí)現(xiàn)Comparable<T>接口
class Student implements Comparable<Student>{
    private String name;
    private int age;

    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 Student(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public Student() {
    }

    @Override
    public int compareTo(Student o) {
        return o.age-this.age;  //從大到小輸出
    }

    @Override
    public String toString() {
        return "Student{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}
public class test {
    public static void main(String[] args) {
        Set<Student> s1 = new TreeSet<Student>((o1, o2) -> o1.getAge() - o2.getAge());
        s1.add(new Student("zhangsan", 23));
        s1.add(new Student("lisi", 22));
        s1.add(new Student("wangwu", 32));
        s1.add(new Student("huyijie", 19));
        System.out.println("s1===================");
        for (Student s : s1) {
            System.out.println(s);
        }
    }
}

2 自定義比較器排序

  • 這種方法需要一個(gè)新的類實(shí)現(xiàn)Comparator<T>接口,重寫其中的Compare方法
  • TreeSet當(dāng)元素不具備比較性,或者比較性不是所需要的時(shí)候,可以使TreeSet集合具有比較性,定義比較器,將比較器作為參數(shù)傳給TreeSet集合,比較器需要實(shí)現(xiàn)Comparator接口,當(dāng)元素具備比較性和比較器同時(shí)出現(xiàn)時(shí),以比較器為準(zhǔn)。
class TestComparator implements Comparator<Student>{

    @Override
    public int compare(Student o1, Student o2) {
        return o1.getAge()-o2.getAge();
    }
}
//(o1, o2) -> o1.getAge() - o2.getAge()
public class test {
    public static void main(String[] args) {
        Set<Student> s1 = new TreeSet<Student>(new TestComparator());
        s1.add(new Student("zhangsan", 23));
        s1.add(new Student("lisi", 22));
        s1.add(new Student("wangwu", 32));
        s1.add(new Student("huyijie", 19));
        System.out.println("s1===================");
        for (Student s : s1) {
            System.out.println(s);
        }
    }
}

也可以通過匿名內(nèi)部類簡(jiǎn)化,

public class test {
    public static void main(String[] args) {
        Set<Student> s1 = new TreeSet<Student>(new Comparator<Student>() {
            @Override
            public int compare(Student o1, Student o2) {
                return o2.getAge()-o1.getAge();
            }
        });
        s1.add(new Student("zhangsan", 23));
        s1.add(new Student("lisi", 22));
        s1.add(new Student("wangwu", 32));
        s1.add(new Student("huyijie", 19));
        System.out.println("s1===================");
        for (Student s : s1) {
            System.out.println(s);
        }
    }
}

可再通過Lambda表達(dá)式簡(jiǎn)化,

三、TreeMap按值排序

首先說一下如果Map對(duì)key進(jìn)行從小到大默認(rèn)排序是創(chuàng)建TreeMap對(duì)象。Map<Integer,Integer> maps = new TreeMap<>();就行了。

那么如何實(shí)現(xiàn)按value排序呢? (把TreeMap的EntrySet轉(zhuǎn)換成list,然后使用Collections.sort排序)

這里使用的是java.util.Collections類實(shí)現(xiàn)排序,將Map轉(zhuǎn)成List,再自定義比較器,代碼如下:

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.TreeMap;
 
public class MapValSort {
    public static void main(String[] args) {
        Map<String, Integer> maps = new TreeMap<String, Integer>();
        maps.put("zhangsan", 22);
        maps.put("lisi", 24);
        maps.put("wangwu", 18);
        maps.put("zhaoliu", 22);
         
        //自定義比較器
        Comparator<Map.Entry<String, Integer>> valCmp = new Comparator<Map.Entry<String,Integer>>() {
            @Override
            public int compare(Entry<String, Integer> o1, Entry<String, Integer> o2) {
                // TODO Auto-generated method stub
                return o2.getValue()-o1.getValue();  // 降序排序,如果想升序就反過來
            }
        };
        //將map轉(zhuǎn)成List,map的一組key,value對(duì)應(yīng)list一個(gè)存儲(chǔ)空間
        List<Map.Entry<String, Integer>> list = new ArrayList<Map.Entry<String,Integer>>(maps.entrySet()); //傳入maps實(shí)體
        Collections.sort(list,valCmp); // 注意此處Collections 是java.util包下面的,傳入List和自定義的valCmp比較器
        //輸出map
        for(int i=0;i<list.size();i++) {
            System.out.println(list.get(i).getKey() + " = " + list.get(i).getValue());
        }
    }
}

四、關(guān)于compareTo方法

  • ompareTo() 方法用于將 Number 對(duì)象與方法的參數(shù)進(jìn)行比較??捎糜诒容^ Byte, Long, Integer等。
  • compareTo方法從第一位開始比較, 如果遇到不同的字符,則馬上返回這兩個(gè)字符的ascii值差值.返回值是int類型

返回參與比較的前后兩個(gè)字符串的asc碼的差值,如果兩個(gè)字符串首字母不同,則該方法返回首字母的asc碼的差值

String a1 = "a";
String a2 = "c";       
System.out.println(a1.compareTo(a2));//結(jié)果為-2

即參與比較的兩個(gè)字符串如果首字符相同,則比較下一個(gè)字符,直到有不同的為止,返回該不同的字符的asc碼差值

String a1 = "aa";
String a2 = "ad";       
System.out.println(a1.compareTo(a2));//結(jié)果為-3

如果兩個(gè)字符串不一樣長(zhǎng),可以參與比較的字符又完全一樣,則返回兩個(gè)字符串的長(zhǎng)度差值

String a1 = "aa";
String a2 = "aa12345678";       
System.out.println(a1.compareTo(a2));//結(jié)果為-8
  • 返回為正數(shù)表示a1>a2, 返回為負(fù)數(shù)表示a1<a2,返回0表示a1==a2。

數(shù)字類型不能用compareTo,nt跟int的比較不能用compareTo方法,直接用大于(>) 小于(<) 或者 等于(==) 不等于(!=)來比較即可

int型可以直接比較,所以沒有用到compareTo比較,如果聲明的是Date、String、Integer、或者其他的,可以直接使用compareTo比較,

Integer n1 = 5;
Integer n2 = 6;
System.out.println(n1.compareTo(n2));//-1

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringBoot整合郵件發(fā)送的四種方法

    SpringBoot整合郵件發(fā)送的四種方法

    這篇文章主要介紹了SpringBoot整合郵件發(fā)送的四種方法,SpringBoot中集成了發(fā)送郵件的功能,本文做了進(jìn)一步優(yōu)化,需要的朋友可以參考下
    2023-03-03
  • Servlet中文亂碼問題解決方案解析

    Servlet中文亂碼問題解決方案解析

    這篇文章主要介紹了Servlet中文亂碼問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • GC調(diào)優(yōu)實(shí)戰(zhàn)之高分配速率High?Allocation?Rate

    GC調(diào)優(yōu)實(shí)戰(zhàn)之高分配速率High?Allocation?Rate

    這篇文章主要為大家介紹了GC調(diào)優(yōu)之高分配速率High?Allocation?Rate的實(shí)戰(zhàn)示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-01-01
  • mybatis中數(shù)據(jù)加密與解密的實(shí)現(xiàn)

    mybatis中數(shù)據(jù)加密與解密的實(shí)現(xiàn)

    數(shù)據(jù)加解密的實(shí)現(xiàn)方式多種多樣,在mybatis環(huán)境中數(shù)據(jù)加解密變得非常簡(jiǎn)單易用,本文主要介紹了mybatis中數(shù)據(jù)加密與解密的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • springboot實(shí)現(xiàn)指定mybatis中mapper文件掃描路徑

    springboot實(shí)現(xiàn)指定mybatis中mapper文件掃描路徑

    這篇文章主要介紹了springboot實(shí)現(xiàn)指定mybatis中mapper文件掃描路徑方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Spring Security認(rèn)證機(jī)制源碼層探究

    Spring Security認(rèn)證機(jī)制源碼層探究

    SpringSecurity是基于Filter實(shí)現(xiàn)認(rèn)證和授權(quán),底層通過FilterChainProxy代理去調(diào)用各種Filter(Filter鏈),F(xiàn)ilter通過調(diào)用AuthenticationManager完成認(rèn)證 ,通過調(diào)用AccessDecisionManager完成授權(quán)
    2023-03-03
  • SpringMVC中Invalid bound statement (not found)常見報(bào)錯(cuò)問題解決

    SpringMVC中Invalid bound statement (not f

    本文主要介紹了SpringMVC中Invalid bound statement (not found)常見報(bào)錯(cuò)問題解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • java聯(lián)調(diào)生成測(cè)試數(shù)據(jù)工具類方式

    java聯(lián)調(diào)生成測(cè)試數(shù)據(jù)工具類方式

    這篇文章主要介紹了java聯(lián)調(diào)生成測(cè)試數(shù)據(jù)工具類方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • springboot如何通過controller層實(shí)現(xiàn)頁(yè)面切換

    springboot如何通過controller層實(shí)現(xiàn)頁(yè)面切換

    在Spring Boot中,通過Controller層實(shí)現(xiàn)頁(yè)面切換背景,Spring Boot的默認(rèn)注解是@RestController,它包含了@Controller和@ResponseBody,@ResponseBody會(huì)將返回值轉(zhuǎn)換為字符串返回,因此無法實(shí)現(xiàn)頁(yè)面切換,將@RestController換成@Controller
    2024-12-12
  • Java Spring WEB應(yīng)用實(shí)例化如何實(shí)現(xiàn)

    Java Spring WEB應(yīng)用實(shí)例化如何實(shí)現(xiàn)

    這篇文章主要介紹了Java Spring WEB應(yīng)用實(shí)例化如何實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-12-12

最新評(píng)論