JAVA Array.sort时间排序问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA Array.sort时间排序问题相关的知识,希望对你有一定的参考价值。

想做一个二维数组的排序,数组的第一列,是类似
2011/02/12 10:00~12:00
2011/03/12 13:00~15:00
2011/05/21 16:00~18:00
2010/12/07 19:00~21:00
的升序排列。
请教各位大牛们~~这样的排序,该怎么写Comparator呢?完全不会了~~

参考技术A 给你一个例子,希望能帮到你。

import java.util.* ;
class Student // 指定类型为Student
private String name ;
private int age ;
public Student(String name,int age)
this.name = name ;
this.age = age ;

public boolean equals(Object obj) // 覆写equals方法
if(this==obj)
return true ;

if(!(obj instanceof Student))
return false ;

Student stu = (Student) obj ;
if(stu.name.equals(this.name)&&stu.age==this.age)
return true ;
else
return false ;


public void setName(String name)
this.name = name ;

public void setAge(int age)
this.age = age ;

public String getName()
return this.name ;

public int getAge()
return this.age ;

public String toString()
return name + "\t\t" + this.age ;

;

class StudentComparator implements Comparator<Student> // 实现比较器
// 因为Object类中本身已经有了equals()方法
public int compare(Student s1,Student s2)
if(s1.equals(s2))
return 0 ;
else if(s1.getAge()<s2.getAge()) // 按年龄比较
return 1 ;
else
return -1 ;


;

public class ComparatorDemo
public static void main(String args[])
Student stu[] = new Student("张三",20),
new Student("李四",22),new Student("王五",20),
new Student("赵六",20),new Student("孙七",22) ;
java.util.Arrays.sort(stu,new StudentComparator()) ; // 进行排序操作
for(int i=0;i<stu.length;i++) // 循环输出数组中的内容
System.out.println(stu[i]) ;


;本回答被提问者和网友采纳

java数组排序问题:array.sort()是从小到大排序,那么如何从大到小排序?

别告诉我从i=a.length开始打印然后i--!因为数组没变啊,只是打印顺序变了。
有木有啥别的方法,除了冒泡插入选择。。。

Integer [] array=new Integer[]1,2,3,4,5;

java.util.Arrays.sort(array, new java.util.Comparator.Comparator<Integer>()
@Override
public int compare(Integer o1, Integer o2)
return o2-o1;

);

Comparator (比较器)是排序的交方法,这个也适合于list的排序
参考技术A 你先用array.sort()从小到大排序,然后我记得array里面应该有个方法叫reverse(),就是把这个数组反过来,也就是从大到小了。
不过这样小数据量还好,大数据效率就不高哈

以上是关于JAVA Array.sort时间排序问题的主要内容,如果未能解决你的问题,请参考以下文章

关于Java中Array.sort()排序原理,越详细越好!

java数组排序问题:array.sort()是从小到大排序,那么如何从大到小排序?

Java在java下Array.Sort和(自己写的)快速排序到底那个快?

更高效地刷OJ——Java中常用的排序方法,Array.sort(),Arrays.parallelSort(), Collections.sort()

Java Array.sort的六种常用方法总结

Java Array.sort的六种常用方法总结