lotus

贵有恒何必三更眠五更起 最无益只怕一日曝十日寒

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

1. 题目

读题

HJ26 字符串排序

 

 

 

考查点

 

2. 解法

思路

 

代码逻辑

 

具体实现

 

public class HJ026 {

public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println(sort(sc.nextLine()));
}

public static String sort(String str) {
char[] array = str.toCharArray();
List<String> list = new ArrayList<>();
for (char c : array) {
if (isLetter(c)) {
list.add(c + "");
}
}
Collections.sort(list, String.CASE_INSENSITIVE_ORDER);

StringBuffer sb = new StringBuffer();
int j = 0;
for (int i = 0; i < array.length; i++) {
char c = array[i];
if (isLetter(c)) {
sb.append(list.get(j++));
} else {
sb.append(c);
}
}
return sb.toString();
}

public static boolean isLetter(char c) {
if (c >= 'a' && c <= 'z' || c >= 'A' && c <= 'Z') {
return true;
}
return false;
}
}

3. 总结

 

 关于  String.CASE_INSENSITIVE_ORDER 的使用

CASE_INSENSITIVE_ORDER 是一个静态字段,它是 String 类的一个 Comparator 类型。它可以用来比较两个字符串,忽略大小写的差异。它的定义在 String 类中,是一个内部类 CaseInsensitiveComparator 的实例。你可以参考这些链接了解更多信息:

 

 

Collections.sort()如何使用自定义比较器?

Collections.sort()是一个用于对List进行排序的方法。如果你想使用自定义比较器,你需要实现Comparator接口,并重写compare方法。比如,如果你有一个Student类,你可以按照id或者name来排序:

public class Student {
    private String name;
    private int id;
    Student(String name, int id) {
        this.name = name;
        this.id = id;
    }
    // getter and setter methods
}

// 按照id排序
Collections.sort(list, new Comparator<Student>() {
    @Override
    public int compare(Student s1, Student s2) {
        return s1.getId() - s2.getId();
    }
});

// 按照name排序
Collections.sort(list, new Comparator<Student>() {
    @Override
    public int compare(Student s1, Student s2) {
        return s1.getName().compareTo(s2.getName());
    }
});

 

posted on 2023-07-14 21:09  白露~  阅读(73)  评论(0编辑  收藏  举报