欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

java 对象数组排序

程序员文章站 2024-03-04 14:32:17
废话不多说直接奉上代码先: import java.util.*; import java.io.*; public class main{ stati...

废话不多说直接奉上代码先:

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按照什么规则来比较两个对象的大小。

以上所述就是本文的全部内容了,希望大家能够喜欢。