java 对象数组排序
废话不多说直接奉上代码先:
import java.util.*; import java.io.*; public class main{ static int [] dp = new int [1010]; public static void main(string [] args)throws ioexception{ mouse [] mice = new mouse [1010]; filereader fr=new filereader("in.txt"); //读取文件 bufferedreader read = new bufferedreader(fr); string str = ""; int n=1; while((str = read.readline())!=null){ string [] s= str.split(" "); mice[n] = new mouse(); //对象实例化,很重要 mice[n].weight = integer.parseint(s[0]); mice[n].speed =integer.parseint(s[1]); n++; } system.out.println(n); arrays.sort(mice,1,n); //sort(int start,int end) 包括start索引,不包括end索引 for(int i=1;i<n;i++){ system.out.println(mice[i].weight+" "+mice[i].speed); } } } class mouse implements comparable{ //实现comparable接口 int weight; int speed; public int compareto(object o){ //重写compareto方法 mouse m=(mouse)o; return weight>m.weight?1:(weight==m.weight?0:-1); } }
另附上arrays.sort用法:
1. 数字排序 int[] intarray = new int[] { 4, 1, 3, -23 };
arrays.sort(intarray);
输出: [-23, 1, 3, 4]
2. 字符串排序,先大写后小写 string[] strarray = new string[] { "z", "a", "c" };
arrays.sort(strarray);
输出: [c, a, z]
3. 严格按字母表顺序排序,也就是忽略大小写排序 case-insensitive sort
arrays.sort(strarray, string.case_insensitive_order);
输出: [a, c, z]
4. 反向排序, reverse-order sort
arrays.sort(strarray, collections.reverseorder());
输出:[z, a, c]
5. 忽略大小写反向排序 case-insensitive reverse-order sort
arrays.sort(strarray, string.case_insensitive_order);
collections.reverse(arrays.aslist(strarray));
输出: [z, c, a]
6、对象数组排序
要对一个对象数组排序 ,则要自己实现java.util.comparator接口
例子:
common_user[] userlisttemp=new common_user[temp.size()];
arrays.sort(userlisttemp, new pinyincomparator());
pinyincomparator 实现了comparator接口,重写了compare方法,来告诉arrays按照什么规则来比较两个对象的大小。
以上所述就是本文的全部内容了,希望大家能够喜欢。
下一篇: Python实现注册登录系统