由字母和数字组成的字符串数组,用Java实现排序
时间: 2023-12-03 22:47:47 浏览: 42
可以使用Java内置的Arrays类中的sort方法来对字符串数组进行排序。该方法默认按字典序升序排序。
示例代码:
```java
import java.util.Arrays;
public class StringArraySort {
public static void main(String[] args) {
String[] arr = { "abc", "123", "def", "456" };
// 排序前
System.out.println("排序前:");
System.out.println(Arrays.toString(arr));
// 排序
Arrays.sort(arr);
// 排序后
System.out.println("排序后:");
System.out.println(Arrays.toString(arr));
}
}
```
输出结果:
```
排序前:
[abc, 123, def, 456]
排序后:
[123, 456, abc, def]
```
相关问题
数组内由大写字母和数字组成相同长度特征的字符串组成,用Java 实现排序
您好,可以使用Java中的Arrays.sort()方法和Comparator接口来实现排序。以下是一个示例代码:
```java
import java.util.Arrays;
import java.util.Comparator;
public class StringSorter {
public static void main(String[] args) {
String[] arr = {"A1B2", "C3D4", "E5F6", "G7H8", "I9J10"};
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 len = s1.length();
for (int i = 0; i < len; i++) {
char c1 = s1.charAt(i);
char c2 = s2.charAt(i);
if (c1 != c2) {
return c1 - c2;
}
}
return 0;
}
}
```
在上述代码中,我们先定义了一个StringSorter类和一个StringComparator类。StringSorter类中定义了一个String类型的数组arr,数组中包含了一些由大写字母和数字组成相同长度特征的字符串。然后,我们使用Arrays.sort方法对这个数组进行排序,排序时需要传入一个Comparator类型的比较器,这里我们传入了我们自己定义的StringComparator对象。
在StringComparator类中,我们实现了Comparator接口的compare方法。在比较两个字符串时,我们先比较它们的第一个字符,如果不相等,则返回它们的ASCII码值之差;如果相等,则继续比较它们的下一个字符,直到比较完所有字符。如果两个字符串完全相等,则返回0。
最后,我们可以看到输出的结果是按照相同长度特征排序的。
数组内的字符串有大写字母和数字组成,用Java实现按照不同位字符排序
您好,可以使用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码值;如果两个字符一个是数字一个是字母,则按照数字优先的原则进行比较。
最后,我们可以看到输出的结果是按照不同位字符排序的。