961. N-Repeated Element in Size 2N Array
Problem Description
You are provided with an integer array, nums
, which has some unique properties. The length of the array is 2n
, indicating that it consists of twice the quantity of a certain number n
. Within this array, there are n + 1
distinct elements, meaning there are only a few unique elements. Among these unique elements, there is one particular element that appears exactly n
times. The challenge here is to identify that one element which is repeated n
times and return it.
Intuition
The intuition behind the solution lies in understanding the properties of the set data structure and the constraints mentioned in the problem. A set in Python is a collection that is unordered and unindexed, and most importantly, it does not allow duplicate elements. Since we know there are n
repeats of the same element and only n + 1
unique elements in the array, we can iterate through the array and add each element to the set.
The moment we encounter an element that's already present in the set, we know that it must be the one that is repeated n
times. This is because we can only add unique elements to the set, and trying to add a duplicate will not change the set, thus highlighting the repeat. Once we identify the repeated element, we can immediately return it, as we are guaranteed by the problem's properties that only one element is repeated n
times.
Solution Approach
The implementation of the solution directly follows the intuition. Here's a step-by-step walk-through of the implementation, which is quite simple and efficient due to the particular constraints of the problem:
-
A set,
s
, is created to keep track of the unique elements we encounter in thenums
array. In Python, a set is valuable because it stores elements in an unordered fashion and, most importantly for our case, does not allow duplicates. -
We iterate over each element
x
in the arraynums
. For each element, we perform a check to determine whether it already exists in the sets
. -
If
x
is not present in the set (which means this is the first time we're seeing this number), we add it to the set usings.add(x)
. -
If
x
is already in the sets
, then it means we have found the duplicate element which has occurredn
times, in compliance with the problem's constraints. We then immediately returnx
. -
The loop will continue until the condition in step 4 is met, which is guaranteed to happen since we know from the problem statement that one element is repeated
n
times.
By using the set and leveraging its properties, we avoid having to compare each element with every other element, which would be a less efficient approach. The use of a set provides a quick and concise way to detect the repeat without additional memory for counting or additional nested loops, making this algorithm run in O(n) time complexity and O(n) space complexity, where n is the number of unique elements in the array.
Ready to land your dream job?
Unlock your dream job with a 2-minute evaluator for a personalized learning plan!
Start EvaluatorExample Walkthrough
Let's illustrate the solution approach with a small example. Suppose we are given an array nums
with the following elements: [1, 2, 3, 3]
.
Following the step-by-step solution:
-
First, we create an empty set
s
to store unique elements we encounter in thenums
array. Initially,s = {}
. -
We start iterating over each element
x
in thenums
array.- On the first iteration,
x = 1
. Since1
is not in the sets
, we add1
tos
. Nows = {1}
. - On the second iteration,
x = 2
. Since2
is not ins
, we add2
tos
. Nows = {1, 2}
. - On the third iteration,
x = 3
. Since3
is not ins
, we add3
tos
. Nows = {1, 2, 3}
. - On the fourth iteration,
x = 3
again. But this time,3
is already ins
, so we have found our duplicate element.
- On the first iteration,
-
As soon as we find that
3
is already in the sets
, we don't need to look any further. We immediately return3
as the duplicate element that is repeatedn
(2) times.
This example showed how the algorithm efficiently traverses the array and uses a set to find the repeating element without the need for unnecessary comparisons or additional memory for counts. The implementation matches the intuition and the problem constraints, offering a simple yet powerful solution.
Solution Implementation
1from typing import List
2
3class Solution:
4 def repeatedNTimes(self, nums: List[int]) -> int:
5 """
6 Find the element that is repeated N times in the given list, where the list size is 2N.
7
8 Args:
9 nums: List[int] - A list of integers with size 2N.
10
11 Returns:
12 int - The integer that is repeated N times.
13 """
14
15 seen = set() # Initialize an empty set to keep track of seen elements.
16
17 for num in nums:
18 if num in seen:
19 # If the number is already in the set, we have found our repeated element.
20 return num
21 # Add the current number to the set.
22 seen.add(num)
23
24 # The function should always return within the loop for well-formed inputs.
25 # An explicit return None could be added here, but it's unnecessary.
26
1class Solution {
2 // This method finds the element that is repeated N times in the array `nums`.
3 public int repeatedNTimes(int[] nums) {
4 // Create a HashSet to store unique elements.
5 // The initial capacity is set to nums.length / 2 + 1 because we know there is
6 // one element repeating N times in a 2N sized array.
7 Set<Integer> uniqueElements = new HashSet<>(nums.length / 2 + 1);
8
9 // Iterate through each element in the array.
10 for (int i = 0;; ++i) { // the loop will break from the inside so no condition is set here
11 // Attempt to add the current element to the HashSet.
12 // If the add() method returns false, it means the element is already in the set
13 // and hence, it is the element that repeats N times.
14 if (!uniqueElements.add(nums[i])) {
15 // Return the repeated element.
16 return nums[i];
17 }
18 }
19 // Since there must be an N times repeated element by the problem statement, the loop
20 // is guaranteed to return at some point and does not require an explicit termination condition.
21 }
22}
23
1#include <vector>
2#include <unordered_set>
3
4class Solution {
5public:
6 // Function to find the element that is repeated N times in the array
7 int repeatedNTimes(vector<int>& nums) {
8 // Create an unordered set to keep track of visited elements
9 unordered_set<int> visitedElements;
10
11 // Iterate over the array
12 for (int i = 0; i < nums.size(); ++i) {
13 // Check if the current element is already in the set
14 if (visitedElements.count(nums[i])) {
15 // If it is in the set, we've found the repeated element
16 return nums[i];
17 }
18 // If it is not in the set, add the current element to the set
19 visitedElements.insert(nums[i]);
20 }
21
22 // If the loop completes without returning, there is a problem with the input
23 // as the problem definition guarantees a repeated element
24 // However, the return statement below is needed to avoid a compiler error.
25 return -1;
26 }
27};
28
1/**
2 * Finds the element that is repeated N times in an array where all other elements appear exactly once.
3 *
4 * @param {number[]} elements - An array of numbers which contains a unique element and one element repeated N times.
5 * @returns {number} - The number that is repeated N times.
6 */
7function repeatedNTimes(elements: number[]): number {
8 // Initialize a new Set to store unique elements as we encounter them.
9 const uniqueElements: Set<number> = new Set();
10
11 // Iterate through each number in the array.
12 for (const element of elements) {
13 // Check if the current element is already in the Set.
14 if (uniqueElements.has(element)) {
15 // If so, we have found our repeated element and return it.
16 return element;
17 }
18 // Otherwise, add the element to the Set of unique elements.
19 uniqueElements.add(element);
20 }
21
22 // The function assumes that there will always be a repeated element,
23 // so there is no explicit return statement outside the loop.
24 // TypeScript will infer that the end of the function is unreachable code.
25 // If the input is guaranteed to always have a repeated element, this is fine.
26 // Otherwise, you should handle the case where no element is repeated:
27 // throw new Error('No repeated element found');
28}
29
Time and Space Complexity
The given Python code aims to find an element that is repeated N
times in a list where 2N
elements are present, and N-1
elements are unique.
Time Complexity
The time complexity is O(N)
because the function iterates through each element of the list exactly once in the worst case (where N
is the length of the list).
Space Complexity
The space complexity is also O(N)
as it uses a set to store elements encountered in the list. In the worst case, this set will store N-1
elements when the repeated element is the last one to be checked.
Learn more about how to find time and space complexity quickly using problem constraints.
Which data structure is used to implement priority queue?
Recommended Readings
Patterns The Shortest Path Algorithm for Coding Interviews The goal of AlgoMonster is to help you get a job in the shortest amount of time possible in a data driven way We compiled datasets of tech interview problems and broke them down by patterns This way we can determine the
Recursion Recursion is one of the most important concepts in computer science Simply speaking recursion is the process of a function calling itself Using a real life analogy imagine a scenario where you invite your friends to lunch https algomonster s3 us east 2 amazonaws com recursion jpg You first
Runtime Overview When learning about algorithms and data structures you'll frequently encounter the term time complexity This concept is fundamental in computer science and offers insights into how long an algorithm takes to complete given a certain input size What is Time Complexity Time complexity represents the amount of time
Got a question?ย Ask the Monster Assistantย anything you don't understand.
Still not clear? ย Submitย the part you don't understand to our editors. Or join ourย Discord and ask the community.