发布网友 发布时间:2022-04-22 22:41
共4个回答
热心网友 时间:2022-04-22 11:45
用Collections.sort就可以排序,
里面的排序是默认的按自然顺序排列
也就是1,2,3,4这种
参数要求实现了Comparable的数据才能排序,
如果你自己写的类,你就要实现Comparable接口,然后在接口里面自动生成的方法里面
指定排序方法,一般的String Inteneger类都是实现了这个接口的 不用自己操作的。
你可以取看源代码
热心网友 时间:2022-04-22 13:03
java的集合排序可以这样做:
(1)新建排序规则
package com.test;(2)利用排序规则进行排序
结果如下:
追问3q 出来了,好高端的算法啊,Comparator这是一个接口吗?
Number num1 = (Number) o1;
Number num2 = (Number) o2;
这两句o1传过来的是一个列表,02是一个类的实例,怎么能比较是否相等呢
感觉没有地方调用compare()函数,返回值是给哪个啊,1,0,-1分别起什么作用啊
好复杂……
追答这是java内置的比较接口,在使用Collections.sort(a, comparatorNumber);的时候java会自动调用所写的比较方法进行数据的比较排序的,此方法不仅用于数字的排序,也可用于字符串的排序,字符串排序时比较可用str1.compareTo(str2)的方式得到比较结果。
1,0,-1其实是比较结果的一个标识【也可用大于0或小于0的其他数值返回】,0表示比较结果是两个内容是一样的,大于0的结果则表示前者大于后者,而小于0的数字则表示后者大于前者
热心网友 时间:2022-04-22 14:38
问题在于
double temp =0.0;你把temp设置成double型,然后
temp =arr.get(l).doubleValue();所以你把取得的int类型转换成了double类型,最后输出就带上了.0
你仔细看看你的程序,int类型有的排序后没有变,有的变x.0了,凡是加上.0的都是它在排序过程中与double类型的数字进行过交换。
追答
你把
换成下面这个,用Number类型做过度元素就可以了
Number temp = null;最后再把
temp =arr.get(l).doubleValue();改成
temp = arr.get(l);最后输出结果就满足要求了!
热心网友 时间:2022-04-22 16:29
先转成数组,在调用Arrays.sort();