我知道有内置的例程,但作为一个学习者,我想使用自己的方法进行排序。由于排序已经老掉牙了,所以我决定尝试制作自己的通用排序例程,可以用于数字或字符串,甚至日期,如果我能弄清楚它们在Java中是如何工作的。
所以这就是我所拥有的,通过交换错误来解决问题,现在只有两个地方出现错误(用“**”标记),需要找出如何进行比较。
package sort;
import java.util.ArrayList;
public abstract class Sort<E> implements Comparable<E> {
public void swap(ArrayList<E> a, int i, int j) {
E c = a.get(i);
a.set(i,a.get(j));// = a[j];
a.set(j, c);
}
public void bubbleSort(ArrayList<E> a) {
boolean inOrder = false;
while (!inOrder) {
inOrder = true;
for (int i = 1; i < a.size(); i++) {
**if( a.get(i - 1).compareTo(a.get(i)) > 0 )** {
//cannot find symbol: method compareTo(E); location: class Object
//where E is a type-variable: E extends Object declared in class Sort
inOrder = false;
swap(a, i, i - 1);
}
}
}
}
public static void main(String args[]) //hadda lose 'static' for 'setLayout' to work
{
ArrayList<Integer> ary = new ArrayList<>();
ary.add(2); ary.add(4); ary.add(7); ary.add(3);
**bubbleSort(ary)**;
//method bubbleSort in class Sort<E> cannot be applied to given types;
//required: ArrayList<E>
//found: ArrayList<Integer>
//reason: actual argument ArrayList<Integer> cannot be converted to ArrayList<E>
//by method invocation conversion where E is a type-variable:
//E extends Object declared in class Sort
for (int i = 0; i < ary.size(); i++) {
System.out.println(ary.get(i));
}
}
@Override
public int compareTo(E o) {
**return 0;** // fixing errors above may help this fall into place
}
}
我试图学习那些我感觉已经准备好了的东西,但却发现我还没有完全准备好;接近成功,但还是失败了。
bubbleSort()
是一个实例方法,你可能想要使用new Sort<Integer>().bubbleSort(ary);
。如果它是一个静态方法,你将需要在方法本身上显式地传递类型参数,在声明方法时将其声明为public static <E extends Comparable<E>> bubbleSort(ArrayList<E> a) {...}
,而不是将类型参数放在此案例中仅充当命名空间的Sort
类上。 - millimooseSort
是抽象的
,它不能被实例化,这意味着在你有一个具体的实现之前,你永远无法执行bubbleSort
方法。根据你的代码,我认为没有必要将这个类声明为抽象的
。 - MadProgrammer