我在使用msort
方法时遇到问题。我没有任何错误,但是当我编译时,
我在以下行中收到错误:
if (((Comparable)arr[midpt-1]).compareTo(arr[midpt]) <= 0)
错误说:
方法CompareTo(Object)属于原始类型Comparable。对泛型类型的引用可以参数化。
一些帮助?
private static void msort(Object[] arr, Object[] tempArr, int first, int last)
{
// if the sublist has more than 1 element continue
if (first + 1 < last)
{
// for sublists of size 2 or more, call msort()
// for the left and right sublists and then
// merge the sorted sublists using merge()
int midpt = (last + first) / 2;
msort(arr, tempArr,first, midpt);
msort(arr, tempArr, midpt, last);
// if list is already sorted, just copy from src to
// dest. this is an optimization that results in faster
// sorts for nearly ordered lists.
if (((Comparable)arr[midpt-1]).compareTo(arr[midpt]) <= 0)
return;
// the elements in the ranges [first,mid) and [mid,last) are
// ordered. merge the ordered sublists into
// an ordered sequence in the range [first,last) using
// the temporary array
int indexA, indexB, indexC;
// set indexA to scan sublist A (index range [first,mid)
// and indexB to scan sublist B (index range [mid, last)
indexA = first;
indexB = midpt;
indexC = first;
// while both sublists are not exhausted, compare arr[indexA] and
// arr[indexB]; copy the smaller to tempArr
while (indexA < midpt && indexB < last)
{
if (((Comparable)arr[indexA]).compareTo(arr[indexB]) < 0)
{
tempArr[indexC] = arr[indexA]; // copy element to tempArr
indexA++; // increment indexA
}
else
{
tempArr[indexC] = arr[indexB]; // copy element to tempArr
indexB++; // increment indexB
}
// increment indexC
indexC++;
}
// copy the tail of the sublist that is not exhausted
while (indexA < midpt)
{
tempArr[indexC] = arr[indexA]; // copy element to tempArr
indexA++;
indexC++;
}
while (indexB < last)
{
tempArr[indexC] = arr[indexB]; // copy element to tempArr
indexB++;
indexC++;
}
// copy elements from temporary array to original array
for (int i = first; i < last; i++)
arr[i] = tempArr[i];
}
}
答案 0 :(得分:3)
由于您正在对@Suppresswarnings
执行未经检查的强制转换,因此无法在不使用Comparable
的情况下删除所有警告。
由于您要求内部将Object
转换为Comparable
,因此在方法声明中声明这一点会更有意义:
private static <T extends Comparable<T>> void msort(T[] arr, T[] tempArr, int first, int last) {
然后您的比较行变为:
if (arr[midpt - 1].compareTo(arr[midpt]) <= 0) {