Table of contents
Open Table of contents
Description
Question links: LeetCode 1346
Given an array arr
of integers, check if there exist two indices i
and j
such that :
i != j
0 <= i, j < arr.length
arr[i] == 2 * arr[j]
Example 1:
Input: arr = [10,2,5,3]
Output: true
Explanation: For i = 0 and j = 2, arr[i] == 10 == 2 * 5 == 2 * arr[j]
Example 2:
Input: arr = [3,1,7,11]
Output: false
Explanation: There is no i and j that satisfy the conditions.
Constraints:
2 <= arr.length <= 500
-10^3 <= arr[i] <= 10^3
Hint 1
Loop from i = 0 to arr.length, maintaining in a hashTable the array elements from [0, i-1]
.
Hint 2
On each step of the loop check if we have seen the element 2 * arr[i]
so far.
Hint 3
Also check if we have seen arr[i] / 2
in case arr[i] % 2 == 0
.
Solution
Idea
We can iterate through the array and use a hashset to store the elements already seen.
- If the double of the current element is already seen or the number’s half is already seen, we return true.
- If no such pairs are present, we return false.
Complexity: Time , Space .
Python
class Solution:
def checkIfExist(self, arr: list[int]) -> bool:
seen = set()
for n in arr:
if 2 * n in seen or (n % 2 == 0 and n // 2 in seen):
return True
seen.add(n)
return False