【发布时间】:2015-07-22 04:47:13
【问题描述】:
所以我尝试使用线性排序按字母顺序对单词进行排序,如果已经有类似的单词,则删除该单词。我使用了以下方法:
import java.util.Arrays;
public class Sorting {
public static void main(String[] args) {
String[] array = new String[] { "pepperoni", "ham", "bacon",
"pineapple", "ham", "sausage", "onion", "bacon" };
System.out.println("Before sorting: " + Arrays.toString(array));
for (int i = 0; i < array.length; i++) {
int min = i;
for (int j = i; j < array.length; j++) {
if (array[min].compareTo(array[j]) > 0) {
min = j;
}
else if (array[min].equals(array[j]) == true) {
array[j] = "";
}
}
String tmp = array[i];
array[i] = array[min];
array[min] = tmp;
}
System.out.println("After sorting: " + Arrays.toString(array));
}
}
但是一切都被删除了。如果没有else if 语句,它将被整理出来,但随着它,一切都会被删除。
Before sorting: [pepperoni, ham, bacon, pineapple, ham, sausage, onion, bacon]
After sorting: [, , , , , , , ]
有人能指出这段代码有什么问题吗?
【问题讨论】:
-
if(array[min].equals(array[j]) == true)?见stackoverflow.com/questions/404838/…