我得到一个问题,说合并已经排序了2个LinkedList,并将最终输出作为Sorted LinkedList。 所以我使用了合并排序算法的合并方法并得到了输出, 它实际上是正确的方式,或者我应该采取其他方式。
以下是用于理解的代码 -
private <T extends Comparable<T>> List<T> merge(List<T> left , List<T> right){
List<T> result = new ArrayList<T>();
while(left.size()>0 && right.size()>0){
//Left is less than right
if(left.get(0).compareTo(right.get(0))<0)
result.add(left.remove(0)); //add the left if small and remove it from the list
else
result.add(right.remove(0));
}
//if left size is greater than 0 , the needed to add left to result
//it proves that if any of the sizes of left/right is more then those are greater size
if(left.size()>0)
result.addAll(left);
else
result.addAll(right);
return result;
}
我的输入 -
List<String> sorted1 = new LinkedList<String>();
sorted1.add("Asdsd");
sorted1.add("ReR");
sorted1.add("asdasd");
sorted1.add("ghjhj");
sorted1.add("zxcxc");
List<String> sorted2 = new LinkedList<String>();
sorted2.add("Awdf");
sorted2.add("Gautom");
sorted2.add("asa");
sorted2.add("ggg");
sorted2.add("qwq");
sorted2.add("rtrt");
System.out.println("ORIGINAL SoRTED LIST\n" +
"=================\n" +
sorted1 + "and "+sorted2+"\n");
List<String> sorted_String2 = new MergeSortAbhishek().merge(sorted1,sorted2);
System.out.println("\nFINAL SORTED LIST\n" +
"=================\n" +
sorted_String2 + "\n");
答案 0 :(得分:0)
听起来对我不错。如果没有看到“merge arg from merge sort”所代表的代码,就不能肯定地说,但概念是正确的。
仅供参考,这对于Code Review网站来说是一个更合适的问题。
答案 1 :(得分:0)
我个人更喜欢使用特殊的方法来完全合并2个排序列表。来自merge
的{{1}}方法可能会混淆,因为您没有对任何内容进行排序。这种方法可能会做一些特殊的排序操作。