算法题:有序数组合并

发布时间:2024年01月17日

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

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]<nums2[p2]){
                cur = nums2[p2--];
            }else{
                cur = nums1[p1--];
            }
            nums1[tail--] = cur;
        }
    }

文章来源:https://blog.csdn.net/u010389826/article/details/135654252
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。