java comparator排序_java排序comparator

packageday05;importjava.util.ArrayList;importjava.util.Collections;importjava.util.Comparator;importjava.util.List;publicclassB_paixu{publicstaticvoidmain(String[]args){/...

package day05;

import java.util.ArrayList;

import java.util.Collections;

import java.util.Comparator;

import java.util.List;

public class B_paixu {

public static void main(String[] args) {

// TODO Auto-generated method stub

List list=new ArrayList();

list.add("BigBossm");

list.add("ben");

list.add("jazz");

list.add("adm");

list.add("Marry");

list.add("bill");

list.add("Xiloer");

list.add("Kate");

list.add("killer");

/**比较器:comparator

* 排序要求(自定义要求):字母少的在前

* 定义一个比较器,比较规则为字母少的小

* 返回值>0:o1>02

* 返回值<0:o1<02

* 返回值=0:o1=02

*/

Comparator comp=new Comparator(){

public int compare(String o1,String o2){

return o1.length()-o2.length();

}

};

Collections.sort(list,comp);

System.out.println(list);

}

}

输出结果:[adm, ben, Kate, bill, jazz, Marry, Xiloer, killer, BigBossm]

我的问题是:怎么从compare()方法中看出是从字母少到字母多排序的。

把return改为return o2.length()-o1.length();后又从字母多到字母少排序了,如下

[BigBossm, Xiloer, killer, Marry, Kate, bill, jazz, adm, ben]

怎么从compare中看出排序结果的,跟sort又有怎样的联系

很抱歉我没有财富值,麻烦不介意的帮我解释一下

展开

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值