java字符串通过什么来排序,字符串是怎么比较大小的
展开全部
答案:java中所有类的排序是根据该类中的toString方法来排序的,你可以通过查看String类的底层代码找到其toString()方法来看他是如何排序的。这是原理
对于单独这个问题:字符串排序时根据字符串第一个字符的按照自然顺序排序
自然顺序:例如如果第一个是数字,则按照从小到大排序,如果第一个字符相同则再比较第二个字符
以此类推,对于字母则根据26个英文字母的顺序决定。
=======================如果是你想问的请给最佳回答,有不懂得可以追问==========谢谢。
对于单独这个问题:字符串排序时根据字符串第一个字符的按照自然顺序排序
自然顺序:例如如果第一个是数字,则按照从小到大排序,如果第一个字符相同则再比较第二个字符
以此类推,对于字母则根据26个英文字母的顺序决定。
=======================如果是你想问的请给最佳回答,有不懂得可以追问==========谢谢。
展开全部
使用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数组 然后依次比对字符.
下边这个就是具体内容
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码来比较
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
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));
}
}
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()这个方法来排序,但是它是通过什么规则来排的呢。还有就是两个字符串是怎样比较大小得
追答
冒泡排序听过吗?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
jdk给了String的源码的,点进去看就知道了。
String实现了Comparable接口的。看compareTo就知道了。
compareTo的协定是:相等返回0,大于返回正数,小于返回负数。
看string整体上来说,还是比较费力的。如果你没有数据结构方面的知识,看起来更费力。
借助eclipse的outlook,抓住脉络,看大概,基本上还是能理解点点的。
String实现了Comparable接口的。看compareTo就知道了。
compareTo的协定是:相等返回0,大于返回正数,小于返回负数。
看string整体上来说,还是比较费力的。如果你没有数据结构方面的知识,看起来更费力。
借助eclipse的outlook,抓住脉络,看大概,基本上还是能理解点点的。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询