使用内置排序函数,时间复杂度On^2
class Solution {
public void merge(int[] nums1, int m, int[] nums2, int n) {
int j=0,i=m;
while(j<n){
nums1[i++]=nums2[j++];
}
Arrays.sort(nums1);
}
}
新建一个临时数组用于放排序后的元素,再将临时数组赋值给nums1,此方法仅遍历一次两个数组,时间复杂度Om+n
class Solution {
public void merge(int[] nums1, int m, int[] nums2, int n) {
int k=m+n;
int[] temp=new int[k];
for(int index=0,nums1Index=0,nums2Index=0;index<k;index++){
if(nums1Index>=m){
temp[index]=nums2[nums2Index++];
}else if(nums2Index>=n){
temp[index]=nums1[nums1Index++];
}else if(nums1[nums1Index]<nums2[nums2Index]){
temp[index]=nums1[nums1Index++];
}else{
temp[index]=nums2[nums2Index++];
}
}
for(int i=0;i<k;i++){
nums1[i]=temp[i];
}
}
}