Java 的Comparator比较器用法
生活随笔
收集整理的這篇文章主要介紹了
Java 的Comparator比较器用法
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
1.定義:Comparator是外部比較器,用于比較來(lái)對(duì)象與對(duì)象之間的,兩個(gè)對(duì)象進(jìn)行比較,多用于集合排序,而Comparable可以認(rèn)為是一個(gè)內(nèi)比較器,根據(jù)對(duì)象某一屬性進(jìn)行排序的
2.使用方法
1)定義節(jié)點(diǎn)信息
class Node{int x;int y;Node(int x,int y){this.x=x;this.y=y;}@Overridepublic String toString() {return "Node{" +"x=" + x +", y=" + y +'}';} }2)比較器方法
Collections.sort(list, new Comparator<Node>() {/**o1-o2為升序序排列,o2-o1為降序排列,若具體到某一字段,則根據(jù)該字段進(jìn)行排列*/@Overridepublic int compare(Node o1, Node o2) {if (o1.x==o2.x) //若x屬性相等,根據(jù)y來(lái)升序return o1.y-o2.y;return o1.x-o2.x;//x屬性不相等,根據(jù)x來(lái)升序排列} });3)完整代碼
import java.util.*;class Node{int x;int y;Node(int x,int y){this.x=x;this.y=y;}@Overridepublic String toString() {return "Node{" +"x=" + x +", y=" + y +'}';} } public class Main {public static void way(int num[],int n){}public static void main(String[] args) {Node node4=new Node(2,2);Node node3=new Node(2,1);Node node1=new Node(1,2);Node node2=new Node(1,1);Node node5=new Node(3,1);Node node6=new Node(3,2);ArrayList<Node> list=new ArrayList<>();list.add(node1);list.add(node2);list.add(node3);list.add(node4);list.add(node5);list.add(node6);Collections.sort(list, new Comparator<Node>() {/**o1-o2為升序序排列,o2-o1為降序排列,若具體到某一字段,則根據(jù)該字段進(jìn)行排列*/@Overridepublic int compare(Node o1, Node o2) {if (o1.x==o2.x) //若x屬性相等,根據(jù)y來(lái)升序return o1.y-o2.y;return o1.x-o2.x;//x屬性不相等,根據(jù)x來(lái)升序排列}});for (Node node:list) {System.out.println(node.toString());}} }3.結(jié)果如下
總結(jié)
以上是生活随笔為你收集整理的Java 的Comparator比较器用法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 求1~n的全排列组合
- 下一篇: Java实现有向图的拓扑排序