【发布时间】:2012-09-20 11:58:00
【问题描述】:
我需要按字符串的长度对 LinkedList 的字符串进行排序,但希望保持相同长度字符串的顺序(不按字典顺序排序)。
示例输入:
this
is
just
a
test
样本输出:
a
is
this
just
test
我正在尝试使用 Comparable<LinkedList<String>> 和 compareTo 方法执行此操作,但我没有得到正确的输出(我的仍然按字典顺序排序)
public class Q3_sorting implements Comparable<LinkedList<String>> {
Scanner keyboardScanner = null;
LinkedList<String> fileList = new LinkedList<String>();
// [...] 这里有一些代码
public int compareTo(LinkedList<String> o) {
// TODO Auto-generated method stub
o = fileList;
for (int i = 0; i < fileList.size() -1; i++) {
if (fileList.get(i).length() == o.get(i+1).length()) {
return 0;
}
if (fileList.get(i).length() > o.get(i+1).length()) {
return -1;
}
if (fileList.get(i).length() < o.get(i+1).length()) {
return 1;
}
}
然后我使用Q3_sorting sort = new Q3_sorting(args);Collections.sort(sort.fileList);
在我的主要方法中。然后我将列表打印出来......
但我将其作为输出:
a
is
just
test
this
我该如何解决这个问题?
【问题讨论】:
标签: java sorting linked-list comparable