算法题:有序数组合并

将合并结果放入第一个数组中

1.双指针法

 /**
     * 有序数组合并,双指针法
     * @param nums1
     * @param m
     * @param nums2
     * @param n
     */
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        int[] sorted = new int[m + n];
        int p1 = 0,p2=0;
        int cur;
        while (p1 < m || p2 < n){
            if (p1 == m){
                cur = nums2[p2++];
            }else if (p2 == n){
                cur = nums1[p1++];
            }else if (nums1[p1] < nums2[p2]){
                cur = nums1[p1++];
            }else{
                cur = nums2[p2++];
            }
            sorted[p1 + p2 -1] = cur;
        }
        for (int i =0;i< sorted.length;i++){
            nums1[i] = sorted[i];
        }

    }

2.逆向双指针法

 /**
     * 逆向双指针
     * @param nums1
     * @param m
     * @param nums2
     * @param n
     */
    public void merge2(int[] nums1, int m, int[] nums2, int n) {
        int p1 = m -1;
        int p2 = n - 1;
        int cur;
        int tail = m + n - 1;
        while (p1 >=0 || p2 >=0){
            if (p1 == -1){
                cur = nums2[p2--];
            }else if (p2 == -1){
                cur = nums1[p1--];
            }else if (nums1[p1]

你可能感兴趣的:(算法题,算法)