js如何合并两个从小到大排好序的数组,合并结果保持从小到大顺序。要求算法复杂度为O(m+n)。例如:[1, 3, 8],[2, 3, 9]合并结果为:[1, 2, 3, 8, 9]
网友回复
要合并两个从小到大排好序的数组,并保持合并结果从小到大的顺序,可以使用双指针法。这种方法的时间复杂度为 O(m+n),其中 m 和 n 分别是两个数组的长度。
以下是实现该算法的 JavaScript 代码:
function mergeSortedArrays(arr1, arr2) { let mergedArray = []; let i = 0, j = 0; // 遍历两个数组,直到其中一个数组的所有元素都被处理完 while (i < arr1.length && j < arr2.length) { if (arr1[i] <= arr2[j]) { mergedArray.push(arr1[i]); i++; } else { mergedArray.push(a...
点击查看剩余70%