java字符串通过什么来排序,字符串是怎么比较大小的

如题所述

答案:java中所有类的排序是根据该类中的toString方法来排序的,你可以通过查看String类的底层代码找到其toString()方法来看他是如何排序的。这是原理
对于单独这个问题:字符串排序时根据字符串第一个字符的按照自然顺序排序
自然顺序:例如如果第一个是数字,则按照从小到大排序,如果第一个字符相同则再比较第二个字符
以此类推,对于字母则根据26个英文字母的顺序决定。

=======================如果是你想问的请给最佳回答,有不懂得可以追问==========谢谢。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2017-11-05

用的是sort排序,具体是通过compareTo进行冒泡排序得出新序列。

第2个回答  推荐于2017-10-04
使用sort方法来排序是根据compareTo方法来决定的
下边这个就是具体内容
public int compareTo(String anotherString) {
int len1 = count;
int len2 = anotherString.count;
int n = Math.min(len1, len2);
char v1[] = value;
char v2[] = anotherString.value;
int i = offset;
int j = anotherString.offset;
if (i == j) {
int k = i;
int lim = n + i;
while (k < lim) {
char c1 = v1[k];
char c2 = v2[k];
if (c1 != c2) {
return c1 - c2;
}
k++;
}
} else {
while (n-- != 0) {
char c1 = v1[i++];
char c2 = v2[j++];
if (c1 != c2) {
return c1 - c2;
}
}
}
return len1 - len2;
}
基本就是把字符串转换成char数组 然后依次比对字符.追问

最终拆成字符了,还是通过ask码来比较大小的么

追答

是啊 通过askii码来比较

本回答被提问者和网友采纳
第3个回答  2013-03-28
public class Util {
public static void main(String[] args) {
//键盘接受用户输入的数
java.util.Scanner sc = new java.util.Scanner(System.in);
//放入数组,好排序,这里定义double类型就是如果用户输入的小数也可以
double[] arr = new double[16];
//循环用户输入的16个数
for(int i = 1; i <= 16; i++){
System.out.println("请输入第" + i +"个数");
arr[i-1] = sc.nextDouble();
}
//进行排序
java.util.Arrays.sort(arr);
//输出排序后的16个数,顺序是从小到大
System.out.println(java.util.Arrays.toString(arr));
}
}追问

我知道它可以通过sort()这个方法来排序,但是它是通过什么规则来排的呢。还有就是两个字符串是怎样比较大小得

追答

冒泡排序听过吗?

第4个回答  2013-03-29
jdk给了String的源码的,点进去看就知道了。
String实现了Comparable接口的。看compareTo就知道了。
compareTo的协定是:相等返回0,大于返回正数,小于返回负数。
看string整体上来说,还是比较费力的。如果你没有数据结构方面的知识,看起来更费力。
借助eclipse的outlook,抓住脉络,看大概,基本上还是能理解点点的。

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网