[Leetcode] merge sorted array 合并数组
Given two sorted integer arrays A and B, merge B into A as one sorted array.
Note: 
You may assume that A has enough space to hold additional elements from B. The number of elements initialized in A and B are m and n respectively.
题意:给定两已排好的数组,将B合并到A中,A足够长。
思路:归并排序,只不过这题是要保存在A中,题目中的意思是不要开辟新的空间,所以常规的从左到右的归并排序行不通,我们可以从后面开始。这就涉及一个问题了:将数组A和数组B的最后元素相比较后,较大元素放在哪,即下标为多少?因,题中说,A足够大,所以至少m+n个位置,这样我们就可以将较大值放在下标为m+n-1处了。还有一个问题就是,若n>m,这样,主体的算法结束后,我们要考虑,n中的元素如何处理, 毫无疑问,此时m=0了,所以只需将B中的元素对应的赋给A中即可,代码如下:
 class Solution {
 public:
     void merge(int A[], int m, int B[], int n)
     {
         if(n==)    return;
         while(m>&&n>)
         {
             if(A[m-]>B[n-])
             {
                 A[m+n-]=A[m-];
                 m--;
             }
             else
             {
                 A[m+n-]=B[n-];
                 n--;
             }
         }
         while(n>)
         {
             A[m+n-]=B[n-];  //m不写也行,此时,m=0
             n--;
         }
     }
 };
[Leetcode] merge sorted array 合并数组的更多相关文章
- Merge Sorted Array 合并数组并排序
		Given two sorted integer arrays nums1 and nums2, merge nums2 into nums1 as one sorted array. Note:Yo ... 
- LeetCode  Merge Sorted Array 合并已排序的数组
		void merge(int A[], int m, int B[], int n) { int *a=A,*b=B; ,j=; ||m==){ //针对特殊情况,比如A或B中无元素的情况 & ... 
- [LeetCode] Merge Sorted Array  混合插入有序数组
		Given two sorted integer arrays A and B, merge B into A as one sorted array. Note:You may assume tha ... 
- [LeetCode] 88. Merge Sorted Array 合并有序数组
		Given two sorted integer arrays nums1 and nums2, merge nums2 into nums1 as one sorted array. Note: T ... 
- LeetCode 088 Merge Sorted Array 合并两个有序数组
		Given two sorted integer arrays nums1 and nums2, merge nums2 into nums1 as one sorted array.Note:You ... 
- [LeetCode] Merge Sorted Array
		Given two sorted integer arrays A and B, merge B into A as one sorted array. Note:You may assume tha ... 
- [leetcode]Merge Sorted Array @ Python
		原题地址:https://oj.leetcode.com/problems/merge-sorted-array/ 题意:Given two sorted integer arrays A and B ... 
- [Leetcode] Merge Sorted Array (C++)
		我在Github上新建了一个解答Leetcode问题的Project, 大家可以参考, 目前是Java 为主,里面有leetcode上的题目,解答,还有一些基本的单元测试,方便大家起步. 题目: Gi ... 
- 【LeetCode】Merge Sorted Array(合并两个有序数组)
		这道题是LeetCode里的第88道题. 题目描述: 给定两个有序整数数组 nums1 和 nums2,将 nums2 合并到 nums1 中,使得 num1 成为一个有序数组. 说明: 初始化 nu ... 
随机推荐
- 23.3.3 Web存储机制【JavaScript高级程序设计第三版】
			Web Storage 最早是在Web 超文本应用技术工作组(WHAT-WG)的Web 应用1.0 规范中描述的. 这个规范的最初的工作最终成为了HTML5 的一部分.Web Storage 的目的是 ... 
- mysql 常用函数,基本使用
			1:选中排除表1 连接表2 表3 获取选中表1中部分选中表3 的部分 并且设置选中状态select t1.*,if(t2中t3id=t1.id,1,0)as checked from t1 lefet ... 
- python 迭代器 和生成器
			迭代器 # 双下方法 # print([1].__add__([2])) # print([1]+[2]) # 迭代器 # l = [1,2,3] # 索引 # 循环 for # for i in l ... 
- latex02-LaTeX源文件的基本结构
			1.一个latex文件有且仅有一个document环境 %后表示注释 2.latex的导言区用于全局设置. 例如:title\author\date 加入空行是结构更加清晰 为了能正确的使用标题信息, ... 
- python入门——Anaconda安装
			初学Python,可以选择python原始的IDE,但原始的IDE在使用过程中需要自己安装各种包,个人觉得初学者不需要将时间花在这些上面,而是应该直接学习python程序,这些比较杂的事情可以在以后的 ... 
- R语言绘图:箱线图
			使用ggplot2绘制箱线图 ######*****绘制箱线图代码*****####### data1$学区房 <- factor(data1$school, levels = 0:1, lab ... 
- [bzoj5158][Tjoi2014]Alice and Bob
			好羞愧啊最近一直在刷水... 题意:给定序列$c$的$a_i$,构造出一个序列$c$使得$\sum b_i$最大. 其中$a_i$表示以$c_i$结尾的最长上升子序列长度,$b_i$表示以$c_i$为 ... 
- android staido 断点遇到的坑
			今天排查数据布点问题,发现sd卡上面的文件莫名消失. 怎么可能?系统不可能删除你的文件,但是我调试,删除文件的代码, 一直都没有执行啊. 后来发现,子线程里面代码,android stadio 可能断 ... 
- mutation与vuex区别
			vuex- action 1.当点发送过快,页面中渲染的内容与state中的数据不一致,vuex里面的state变得慢,且不持续更新 2.action中是可以做到页面中state中数据保持一致 责 ... 
- sed 集合(项目中的笔记)
			奇数行和偶数行合并为一行: Like: Sequence number: 5398Sequence name: Glyma.16G123500.1Sequence number: 5399Sequen ... 
