力扣简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]; } }*/
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理