Hi, in this tutorial, we are going to discuss an important interview question which is to Merge Two Sorted Arrays efficiently.

## Merge Two Sorted Arrays

This is one of the basic questions that is mostly asked in programming and algorithms interviews. At first, looking at the question, everyone knows for the sorting part, the most efficient algorithm even took O(nlogn), where n is the length of the input array.

So, let’s first talk about the brute force algorithm which comes to every developer’s mind when he/she saw such type of sorting algorithm.

First, we will create a new empty array and copy 1st array elements to it or use one of the existing arrays if space concern is also there and then copy the 2nd input array to the new array or the first array.

Then, we will apply any sorted algorithm like quicksort, merge sort, or any other sorting algorithm. And in this way, we can solve the question.

But, this question doesn’t require that much computation for a single task with complexity O(nlogn), it can easily be done with O(n) time complexity, where n is the sum of the length of 1st array and length of the second array.

When I first saw this question in my early interviews, I was thinking just like what I have mentioned above and missed out on the important information.

Maybe, you got the solution or don’t miss the information in question, then it is perfectly fine but for those who missed the information, then let me tell you, the individual arrays are already sorted.

So, why do we need to sort the whole array again, else we can come up with some logic to work with these sorted arrays?

Yeah, so what we can do is we can start traversing through both arrays inside while loop which will stop iteration when any index reached its array length.

Then inside each iteration, we will compare the first_array index value with the second_array index value, and whichever is lower will be pushed to the new array.

In this way, we will complete iteration from both arrays or maybe completely from one of the arrays whichever index reached its array length.

Then, we need to just copy another array directly to the new array, because the leftovers are already sorted.

So, in this way, we can merge the sorted arrays most efficiently with complexity O(n), where n is the sum of the length of both arrays.

### Souce Code [ Javascript ]

```
const mergeArrays = (arr1, arr2) => {
let res = []
let [i, j] = [0, 0]
while( i < arr1.length && j < arr2.length ) {
if (arr1[i] <= arr2[j]) {
res.push(arr1[i])
i+=1
} else {
res.push(arr2[j])
j+=1
}
}
if (i === arr1.length) {
res = res.concat(...arr2.slice(j))
} else {
res = res.concat(...arr1.slice(i))
}
return res
}
const arr1 = [ 1, 3, 5, 7, 9]
const arr2 = [ 2, 4, 6, 8, 10, 11, 12, 13 ]
console.log(mergeArrays(arr1, arr2))
```

So, this is it for this tutorial on how to merge sorted arrays in the most efficient way in javascript.

I hope you guys like the tutorial, feel free to drop any comments in the comment section down below.