-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy path88.MergeSortedArray.py
48 lines (41 loc) · 1.44 KB
/
88.MergeSortedArray.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
"""
Given two sorted integer arrays nums1 and nums2, merge nums2 into nums1 as
one sorted array.
Note:
The number of elements initialized in nums1 and nums2 are m and n
respectively.
You may assume that nums1 has enough space
(size that is greater or equal to m + n)
to hold additional elements from nums2.
Example:
Input:
nums1 = [1,2,3,0,0,0], m = 3
nums2 = [2,5,6], n = 3
Output: [1,2,2,3,5,6]
"""
#Difficulty: Easy
#59 / 59 test cases passed.
#Runtime: 32 ms
#Memory Usage: 13.8 MB
#Runtime: 32 ms, faster than 88.10% of Python3 online submissions for Merge Sorted Array.
#Memory Usage: 13.8 MB, less than 6.15% of Python3 online submissions for Merge Sorted Array.
class Solution:
def merge(self, nums1: List[int], m: int, nums2: List[int], n: int) -> None:
l = len(nums1)
s = m + n
if s <= l:
for num2 in nums2:
s -= 1
nums1[s] = num2
nums1.sort()
#Difficulty: Easy
#59 / 59 test cases passed.
#Runtime: 28 ms
#Memory Usage: 14.1 MB
#Runtime: 28 ms, faster than 97.31% of Python3 online submissions for Merge Sorted Array.
#Memory Usage: 14.1 MB, less than 6.15% of Python3 online submissions for Merge Sorted Array.
class Solution:
def merge(self, nums1: List[int], m: int, nums2: List[int], n: int) -> None:
for i in range(n):
nums1[m+i] = nums2[i]
nums1.sort()