合並兩個有序數組[Leetcode]


混合插入有序數組,由於兩個數組都是有序的,所以只要按順序比較大小即可。題目中說了nums1數組有足夠大的空間,說明我們不用resize數組,又給了我們m和n,那就知道了混合之后的數組大小,這樣我們就從nums1和nums2數組的末尾開始一個一個比較,把較大的數,按順序從后往前加入混合之后的數組末尾。需要三個變量i,j,k,分別指向nums1,nums2,和混合數組的末尾。進行while循環,如果i和j都大於0,再看如果nums1[i] > nums2[j],說明要把nums1[i]先加入混合數組的末尾,加入后k和i都要自減1;else,就把nums2[j]加入混合數組的末尾,之后j和k也要自減1。循環結束后,有可能i和j還大於等於0,若j大於等於0,那么需要繼續循環,將nums2中的數字繼續拷入nums1。若是i大於等於0,那么就不用管,因為混合數組本身就房子nums1中。

代碼如下:

class Solution{
    public void merge(int nums1 [], int m, int nums2 [], int n){
        int i = m-1, j = n-1, k = m+n-1;
        while(i>=0 && j>=0){
            if(nums1[i] > nums2[j])
                nums1[k--] = nums1[i--];
            else
                nums1[k--] = nums2[j--];     
        }
        while(j>=0){
            nums[k--] = nums[j--];
        }  
    }  
}

 

還可以將兩個while循環整合到一起,只要加上i > =0且nums1[i] > nums2[j]的判斷條件就可以從nums1中取數:

class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        int i = m-1, j = n-1, k = m+n-1;
        while(j>=0){
            nums1[k--] = i >= 0 && nums1[i]>nums2[j] ? nums1[i--] : nums2[j--];
        }
    }
}

nice .

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM