java中TreeMap排序的示例代碼
1. 定義TreeMap的排序方法
使用Comparator對象作為參數(shù)
需要注意的是:排序方法是針對鍵的,而不是值的。如果想針對值,需要更麻煩的一些方法(重寫一些方法)
TreeMap<Screen,Integer> res = new TreeMap<Screen, Integer>(new Comparator<Screen>() {
@Override
public int compare(Screen screen1, Screen t1) { // 定義TreeMap的排序方法
return screen1.compareTo(t1); // TreeMap的排序方法是:調(diào)用screen的比較方法
}
});
2. 定義里面的對象的比較方法
繼承Comparable接口
public class Screen implements Comparable{
private double size,price;
...
@Override
public int compareTo(Object s){ // 定義比較方法
Screen screen = (Screen)s;
return this.price>screen.getPrice()?-1:1; // 返回負(fù)整數(shù)和正整數(shù)
}
}
3. 所有代碼
按照Screen的價錢排序
Screen.java
import java.util.*;
import java.lang.Integer;
public class Screen implements Comparable{
private double size,price;
public Screen(){}
public void setSize(double size){
this.size = size;
}
public void setPrice(double price){
this.price = price;
}
public double getSize(){ return this.size;}
public double getPrice() { return this.price;}
public void show(){
System.out.println("size is: "+this.size+"; price is: "+this.price);
}
@Override
public int compareTo(Object s){ // 定義比較方法
Screen screen = (Screen)s;
return this.price>screen.getPrice()?-1:1; // 返回負(fù)整數(shù)和正整數(shù)
}
}
TestScreen.java
import java.util.Comparator;
import java.util.Scanner;
import java.util.TreeMap;
import problem2.Screen;
public class TestScreen {
final static int MAX_NUM = 8;
public static void main(String []args){
TreeMap<Screen,Integer> res = new TreeMap<Screen, Integer>(new Comparator<Screen>() {
@Override
public int compare(Screen screen1, Screen t1) { // 定義TreeMap的排序方法
return screen1.compareTo(t1); // TreeMap的排序方法是:調(diào)用screen的比較方法
}
});
double price, size;
Scanner scan = new Scanner(System.in);
for(int i=0;i<MAX_NUM;++i){
Screen screen = new Screen();
size = scan.nextDouble();
price = scan.nextDouble();
screen.setSize(size);
screen.setPrice(price);
res.put(screen,i);
}
for(Screen screen:res.keySet()){
screen.show();
}
return ;
}
}
// 測試樣例(輸入)
// 1 2
// 3 4
// 5 6
// 7 8
// 9 10
// 1 2
// 3 4
// 3 4
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
java?byte數(shù)組轉(zhuǎn)String的幾種常用方法
在Java中數(shù)組是一種非常常見的數(shù)據(jù)結(jié)構(gòu),它可以用來存儲多個相同類型的數(shù)據(jù),有時候,我們需要將數(shù)組轉(zhuǎn)換為字符串,以便于輸出或者傳遞給其他方法,這篇文章主要給大家介紹了關(guān)于java?byte數(shù)組轉(zhuǎn)String的幾種常用方法,需要的朋友可以參考下2024-09-09
基于java查找并打印輸出字符串中字符出現(xiàn)次數(shù)
這篇文章主要介紹了基于java查找并打印輸出字符串中字符出現(xiàn)次數(shù),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-11-11
深入分析Comparable與Comparator及Clonable三個Java接口
接口不是類,而是對類的一組需求描述,這些類要遵從接口描述的統(tǒng)一格式進(jìn)行定義,這篇文章主要為大家詳細(xì)介紹了Java的Comparable,Comparator和Cloneable的接口,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-05-05
一篇文章帶你認(rèn)識Java8接口的默認(rèn)方法
這篇文章主要給大家介紹了如何通過一篇文章帶你認(rèn)識Java8接口的默認(rèn)方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Java8具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
基于Java創(chuàng)建XML(無中文亂碼)過程解析
這篇文章主要介紹了基于Java創(chuàng)建XML(無中文亂碼)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-10-10
SpringBoot集成yitter-idgenerator(雪花漂移)分布式Id自增的實現(xiàn)
本文主要介紹了SpringBoot集成yitter-idgenerator(雪花漂移)分布式Id自增的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01

