首页 > 其他分享 >HJ26 字符串排序

HJ26 字符串排序

时间:2023-07-14 21:23:08浏览次数:43  
标签:sort String list Student 字符串 排序 public HJ26 name

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());
    }
});

 

标签:sort,String,list,Student,字符串,排序,public,HJ26,name
From: https://www.cnblogs.com/shoshana-kong/p/17548653.html

相关文章

  • C++将WSAGetLastError转换成字符串信息
    #include<iostream>#include<Windows.h>#include<WinSock2.h>std::stringGetLastErrorMessage(){DWORDerrorCode=WSAGetLastError();LPSTRerrorMessage=nullptr;DWORDresult=FormatMessageA(FORMAT_MESSAGE_ALL......
  • 根据模板自动匹配目标字符串
    好的,让我们模拟一下这段代码的运行,并打印出每一行的结果://声明一个静态的正则表达式模式,用于匹配大括号中的内容privatestaticfinalPatternpattern=Pattern.compile("\\{(.*?)\\}");privatestaticMatchermatcher;//字符串格式化替换方法publicStringformatStr......
  • js实现多列排序
    js实现多列排序根据业务逻辑调整sortData的数据。排序的规则是按照第一列排序,第一列相同按照第二列排序,依次类推//要排序的数据constarray=[{name:'甲'asd,age:10,money:100},{name:'亿',age:10,money:90},{name:'丙',age:9,money:100}]//......
  • java 判断字符串内容是utf-8还是utf8mb4
    判断字符串内容是UTF-8还是UTF8MB4的方法概述在Java中,判断字符串内容是UTF-8还是UTF8MB4可以通过检查字符编码范围来实现。UTF-8使用1到4个字节表示一个字符,而UTF8MB4使用1到4个字节表示一个字符。下面将介绍整个流程和每一步需要做的事情。流程步骤描述1.将字符串转......
  • java 判断以逗号分割的字符串
    Java判断以逗号分割的字符串简介在Java中,判断以逗号分割的字符串可以使用split方法将字符串分割成多个子字符串,然后逐个判断每个子字符串是否满足特定条件。本文将介绍如何使用Java实现这一功能。流程图步骤描述步骤1通过split方法将字符串分割成多个子字符串步......
  • java根据实体类排序
    Java根据实体类排序在Java开发中,我们经常需要对实体类进行排序。排序是一种常见的操作,它能够帮助我们对一组对象按照特定的规则进行排列。本文将介绍如何使用Java对实体类进行排序,并提供代码示例来帮助读者更好地理解。实体类排序概述首先,我们需要了解实体类排序的基本概念。排......
  • mysql的字符串函数
    对于针对字符串位置的操作,第一个位置被标记为1。ASCII(str)返回字符串str的最左面字符的ASCII代码值。如果str是空字符串,返回0。如果str是NULL,返回NULL。mysql>selectASCII('2');    ->50mysql>selectASCII(2);    ->50mysql>selectASCII('dx'); ......
  • 冒泡排序
    #冒泡最大的在最后面#冒泡最大的在后面lis=[4,3,2,1]forjinrange(len(lis)-1):#外循环了len-1次flag=False#添加标记没有交换foriinrange(len(lis)-1):#内循环后找到本次最大的放到了最后iflis[i]>lis[i+1]:lis[i]......
  • 2023-07-13:如果你熟悉 Shell 编程,那么一定了解过花括号展开,它可以用来生成任意字符串
    2023-07-13:如果你熟悉Shell编程,那么一定了解过花括号展开,它可以用来生成任意字符串。花括号展开的表达式可以看作一个由花括号、逗号和小写英文字母组成的字符串定义下面几条语法规则:如果只给出单一的元素x,那么表达式表示的字符串就只有"x"。R(x)={x}例如,表达式"a"......
  • 极角排序
    向量叉积平面向量中,给定两个向量\((x_0,y_0),(x_1,y_1)\),向量叉积定义为\(x_0y_1-y_0x_1\),如果这个值为负数,那么从第一个向量旋转到第二个向量是顺时针,反之则是逆时针,如果两个向量共线,则叉积为\(0\),注意这里旋转的角度是两个向量的夹角。极角排序选定一个点作为极点,一条射线......