数组内的字符串有大写字母和数字组成,用Java实现按照不同位字符排序
时间: 2024-02-27 21:54:02 浏览: 31
您好,可以使用Java中的Comparator接口来实现按照不同位字符排序。以下是一个示例代码:
```java
import java.util.Arrays;
import java.util.Comparator;
public class StringSorter {
public static void main(String[] args) {
String[] arr = {"A1", "B2", "C3", "D4", "E5", "F6", "G7", "H8", "I9", "J10"};
Arrays.sort(arr, new StringComparator());
System.out.println(Arrays.toString(arr));
}
}
class StringComparator implements Comparator<String> {
@Override
public int compare(String s1, String s2) {
int len1 = s1.length();
int len2 = s2.length();
int lim = Math.min(len1, len2);
for (int i = 0; i < lim; i++) {
char c1 = s1.charAt(i);
char c2 = s2.charAt(i);
if (Character.isDigit(c1) && Character.isDigit(c2)) {
int num1 = Integer.parseInt(String.valueOf(c1));
int num2 = Integer.parseInt(String.valueOf(c2));
if (num1 != num2) {
return num1 - num2;
}
} else if (Character.isAlphabetic(c1) && Character.isAlphabetic(c2)) {
if (c1 != c2) {
return c1 - c2;
}
} else {
return Character.compare(c1, c2);
}
}
return len1 - len2;
}
}
```
在上述代码中,我们先定义了一个StringSorter类和一个StringComparator类。StringSorter类中定义了一个String类型的数组arr,数组中包含了一些字符串,这些字符串由大写字母和数字组成。然后,我们使用Arrays.sort方法对这个数组进行排序,排序时需要传入一个Comparator类型的比较器,这里我们传入了我们自己定义的StringComparator对象。
在StringComparator类中,我们实现了Comparator接口的compare方法。在比较两个字符串时,我们先比较它们的长度,然后按照每个字符的ASCII码值进行比较。如果两个字符都是数字,则将它们转换成数字进行比较;如果两个字符都是字母,则直接比较它们的ASCII码值;如果两个字符一个是数字一个是字母,则按照数字优先的原则进行比较。
最后,我们可以看到输出的结果是按照不同位字符排序的。