java把两个有序的list合并的最快速的方法

废话不多说,直接上代码,嘎嘎

 public static List sort(List list1 , List list2){  

        List list = new ArrayList();  
        long startruntime=System.nanoTime();
        int i = 0 , j = 0;  
        ArrayList resultArray = new ArrayList();  
        
        while(i             if(i==list1.size() && j                 resultArray.add(list2.get(j));  
                j++;  
            }else if(i                 resultArray.add(list1.get(i));  
                i++;  
            }else{  
                if(list1.get(i)<=list2.get(j)){  
                    resultArray.add(list1.get(i));  
                    i++;  
                }else if(list1.get(i)>list2.get(j)){  
                    resultArray.add(list2.get(j));  
                    j++;  
                }  
            }  
        } 
              
        long endruntime=System.nanoTime(); //获取开始时间
        System.out.println("===========================此次方法运行时间: " + (endruntime - startruntime) + "ns");
        i =0;
        j = 0;
        startruntime=System.nanoTime();
 
        while(i < list1.size() && j < list2.size()){  
            if(list1.get(i) < list2.get(j)){  
                list.add(list1.get(i++));  
            }else{  
                list.add(list2.get(j++));  
            }  
        }  
        System.out.println(i < list1.size());
        while(i < list1.size()){  
            list.add(list1.get(i++));  
        } 
        System.out.println(j < list2.size());
        while(j < list2.size()){  
            list.add(list2.get(j++));  
        }  
        endruntime=System.nanoTime(); //获取开始时间
        System.out.println("===========================此次方法运行时间: " + (endruntime - startruntime) + "ns");
        System.out.println(resultArray);
        System.out.println(list);
        return list;  
    } 

你可能感兴趣的:(java把两个有序的list合并的最快速的方法)