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又有怎样的联系

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

展开

好的,这是一个关于 Java字母排序的问题。我可以为您提供一些相关的代码和思路。 在 Java 中,可以使用 Comparator 接口来实现对字符串的排序Comparator 接口有一个 compare() 方法,可以按照指定的规则比较两个对象的大小并返回一个整数值。我们可以自定义一个 Comparator 对象来实现字符串的排序。 在对字符串进行排序时,一般是按照字典序进行排序,即先按照第一个字符的 ASCII 码值进行比较,如果相同则继续比较第二个字符,依次类推,直到比较出大小为止。但是,如果字符串中既有字母又有数字、中文等字符,就需要按照一定的规则进行排序,这时就需要自定义一个 Comparator 对象。 下面是一个示例代码,可以实现数字、字母、中文混合排序: ```java import java.text.Collator; import java.util.Comparator; import java.util.Locale; public class MyComparator implements Comparator<String> { private Collator collator = Collator.getInstance(Locale.CHINA); @Override public int compare(String o1, String o2) { // 如果两个字符串相等,则返回0 if (o1.equals(o2)) { return 0; } // 如果两个字符串均为数字,则按照数字大小排序 if (o1.matches("\\d+") && o2.matches("\\d+")) { return Integer.compare(Integer.parseInt(o1), Integer.parseInt(o2)); } // 如果两个字符串均不为数字,则按照字典序排序 if (!o1.matches("\\d+") && !o2.matches("\\d+")) { return collator.compare(o1, o2); } // 如果一个字符串为数字,一个字符串为非数字,则返回非数字字符串大 if (o1.matches("\\d+")) { return 1; } else { return -1; } } } ``` 在这个示例代码中,我们首先使用 Collator 类来比较中文字符的大小,然后根据字符串的类型进行排序。如果两个字符串均为数字,则按照数字大小进行排序;如果两个字符串均不为数字,则按照字典序进行排序;如果一个字符串为数字,一个字符串为非数字,则返回非数字字符串大。 使用这个自定义的 Comparator 对象进行排序时,只需要调用 Collections.sort() 方法并传入该对象即可: ```java List<String> list = new ArrayList<>(); list.add("3"); list.add("a"); list.add("1"); list.add("中文"); Collections.sort(list, new MyComparator()); System.out.println(list); ``` 输出结果为:[1, 3, a, 中文] 希望这个示例代码能够帮助到您!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值