mirror of
https://github.com/TheAlgorithms/Ruby
synced 2025-01-27 19:58:06 +01:00
Add two pointers solution
This commit is contained in:
parent
7b20bca2f8
commit
b0287375a4
1 changed files with 40 additions and 1 deletions
|
@ -61,7 +61,7 @@ def intersect(arr1, arr2)
|
|||
hash[num] -= 1
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
result
|
||||
end
|
||||
|
||||
|
@ -70,6 +70,45 @@ nums2 = [2, 2]
|
|||
puts intersect(nums1, nums2)
|
||||
# => [2,2]
|
||||
|
||||
nums1 = [4, 9, 5]
|
||||
nums2 = [9, 4, 9, 8, 4]
|
||||
puts intersect(nums1, nums2)
|
||||
# => [4,9]
|
||||
|
||||
#
|
||||
# Approach 3: Two Pointers
|
||||
#
|
||||
# Time Complexity: O(n log n)
|
||||
#
|
||||
def intersect(nums1, nums2)
|
||||
result = []
|
||||
p1 = 0
|
||||
p2 = 0
|
||||
nums1 = nums1.sort
|
||||
nums2 = nums2.sort
|
||||
while p1 < nums1.length && p2 < nums2.length
|
||||
if nums1[p1] < nums2[p2]
|
||||
p1 += 1
|
||||
elsif nums1[p1] > nums2[p2]
|
||||
p2 += 1
|
||||
elsif nums1[p1] == nums2[p2]
|
||||
result << nums1[p1]
|
||||
p1 += 1
|
||||
p2 += 1
|
||||
end
|
||||
end
|
||||
|
||||
result
|
||||
end
|
||||
nums1 = [1, 2, 2, 1]
|
||||
nums2 = [2, 2]
|
||||
intersect(nums1, nums2)
|
||||
|
||||
nums1 = [1, 2, 2, 1]
|
||||
nums2 = [2, 2]
|
||||
puts intersect(nums1, nums2)
|
||||
# => [2,2]
|
||||
|
||||
nums1 = [4, 9, 5]
|
||||
nums2 = [9, 4, 9, 8, 4]
|
||||
puts intersect(nums1, nums2)
|
||||
|
|
Loading…
Add table
Reference in a new issue