88. 合并两个有序数组 + 合并数组 + 双指针
2021-06-08 09:05
标签:insert oid 否则 lang sorted -- 循环 而且 lazy 88. 合并两个有序数组 + 合并数组 + 双指针 标签:insert oid 否则 lang sorted -- 循环 而且 lazy 原文地址:https://www.cnblogs.com/GarrettWale/p/14531855.html88. 合并两个有序数组
LeetCode_88
题目描述
方法一:暴力法
class Solution {
public void merge(int[] nums1, int m, int[] nums2, int n) {
for(int i=0, j=0; j
方法二:双指针法
class Solution {
public void merge(int[] nums1, int m, int[] nums2, int n) {
int p = m+n-1;
int p1 = m-1;
int p2 = n-1;
while(p2 >= 0){//注意循环的条件,这里一定是p2>=0,否则出错
if(p1 >= 0 && nums1[p1] > nums2[p2]){
nums1[p] = nums1[p1];
p--;
p1--;
}else{
nums1[p] = nums2[p2];
p--;
p2--;
}
}
}
}