力扣简88 合并两个有序数组

哇 才知道怎么插入代码 这个东西真真不错嘻嘻嘻

之前写了半个小时一直写不对,写到最后已经糊涂了。然后又重新想起来这个新思路。结果还可以。

看了看题解,思路大致相同,但是代码量明显人家简洁很多。对于下面的赋值再加加都写到了一个语句中;对于最后的两个数组未排序部分合并入结果的情况放在了最前面的while模块中。

 

 

复制代码
package leetcode01;

public class Solution88 {
    /*给你两个按非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。
请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非递减顺序 排列。
注意:最终,合并后数组不应由函数返回,而是存储在数组 nums1 中。为了应对这种情况,nums1 的初始长度为 m + n,
其中前 m个元素表示应合并的元素,后 n个元素为 0 ,应忽略。nums2 的长度为 n 。
*/
    //写了一堆狗屁不通哈哈哈哈重新开始吧,敢错是种美德。
    public static void merge(int[] nums1, int m, int[] nums2, int n) {
        int flag1=0;//标记两数组中的比较位置
        int flag2=0;
        int num=0;//标记已经是最终排序的数字个数
        int[] temp=new int[m];
        for(int i=0;i<m;i++) {
            temp[i]=nums1[i];
        }
        while(flag1<m&&flag2<n) {
            if(temp[flag1]<=nums2[flag2]) {
                nums1[num]=temp[flag1];
                flag1++;
            }
            else {
                nums1[num]=nums2[flag2];
                flag2++;
            }
            num++;
        }
        if(flag1<m) {
            for(int i=flag1;i<m;i++,num++) {
                nums1[num]=temp[i];
            }
        }
        else if(flag2<n) {
            for(int i=flag2;i<n;i++,num++) {
                nums1[num]=nums2[i];
            }
        }
        
    }

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int[] nums1 = {1,2,3,9,0,0,0};
        int[] nums2 = {2,5,6}; 
        merge(nums1, 4, nums2,3);
        for(int i=0;i<nums1.length;i++) {
            System.out.println("nums1["+i+"] is "+nums1[i]);
        }
    }

}



/*        int[] temp=nums1;
        int flag=0;
        int num=0;
        for(int i=0;i<n;i++) {
            while(nums2[i]>=temp[flag]&&flag<m) {
                flag++;
            }
            nums1[flag]=nums2[i];
            num++;
            if(flag==m) {
                for(int j=num+m;j<m+n;j++) {
                    nums1[j]=temp[flag];
                }
            }
        }*/
复制代码

 

//这是题解1:运用内部排序库
    public static void merge(int[] nums1, int m, int[] nums2, int n) {
        for(int i=m,j=0;i<m+n;++i,++j) {
            nums1[i]=nums2[j];
        }
        Arrays.sort(nums1);
    }
复制代码
/*这是题解2 把情况合并,代码量少, 占内存小。 */
    /*题解2改进为3:之所以要使用临时变量,是因为如果直接合并到数组nums1中,nums1中的元素可能会在取出之前被覆盖。
             那么如何直接避免覆盖 nums1中的元素呢?观察可知,nums1的后半部分是空的,可以直接覆盖而不会影响结果。
             因此可以指针设置为从后向前遍历,每次取两者之中的较大者放进nums 1的最后面。*/
/*    public static void merge(int[] nums1, int m, int[] nums2, int n) {
        int p1 = 0, p2 = 0;
        int[] sorted = new int[m + n];
        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 != m + n; ++i) {
            nums1[i] = sorted[i];
        }
    }*/
复制代码

 

posted @   Ssshiny  阅读(79)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示