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

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

 public static List<Integer> sort(List<Integer> list1 , List<Integer> list2){  

        List<Integer> list = new ArrayList<Integer>();  
        long startruntime=System.nanoTime();
        int i = 0 , j = 0;  
        ArrayList<Integer> resultArray = new ArrayList<Integer>();  
        
        while(i<list1.size() || j<list2.size()){  
            if(i==list1.size() && j<list2.size()){  
                resultArray.add(list2.get(j));  
                j++;  
            }else if(i<list1.size() && j==list2.size()){  
                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;  
    } 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值