LeetCode 0137. Single Number II Solution in Java, Python, C++, JavaScript, Go & Rust | Explanation + Code

CoderIndeed
0
0137. Single Number II

Description

Given an integer array nums where every element appears three times except for one, which appears exactly once. Find the single element and return it.

You must implement a solution with a linear runtime complexity and use only constant extra space.

 

Example 1:

Input: nums = [2,2,3,2]
Output: 3

Example 2:

Input: nums = [0,1,0,1,0,1,99]
Output: 99

 

Constraints:

  • 1 <= nums.length <= 3 * 104
  • -231 <= nums[i] <= 231 - 1
  • Each element in nums appears exactly three times except for one element which appears once.

Solutions

Solution 1: Bitwise Operation

We can enumerate each binary bit i, and for each binary bit, we calculate the sum of all numbers on that bit. If the sum of the numbers on that bit can be divided by 3, then the number that only appears once on that bit is 0, otherwise it is 1.

The time complexity is O(n × log M), where n and M are the length of the array and the range of elements in the array, respectively. The space complexity is O(1).

PythonJavaC++GoTypeScriptJavaScriptRustCSwift
class Solution: def singleNumber(self, nums: List[int]) -> int: ans = 0 for i in range(32): cnt = sum(num >> i & 1 for num in nums) if cnt % 3: if i == 31: ans -= 1 << i else: ans |= 1 << i return ans(code-box)

Solution 2: Digital Circuit

We can use a more efficient method that uses digital circuits to simulate the above bitwise operation.

Each binary bit of an integer can only represent 2 states, 0 or 1. However, we need to represent the sum of the i-th bit of all integers traversed so far modulo 3. Therefore, we can use two integers a and b to represent it. There are three possible cases:

  1. The i-th bit of integer a is 0 and the i-th bit of integer b is 0, which means the modulo 3 result is 0;
  2. The i-th bit of integer a is 0 and the i-th bit of integer b is 1, which means the modulo 3 result is 1;
  3. The i-th bit of integer a is 1 and the i-th bit of integer b is 0, which means the modulo 3 result is 2.

We use integer c to represent the number to be read in, and the truth table is as follows:

a_i b_i c_i New a_i New b_i
0 0 0 0 0
0 0 1 0 1
0 1 0 0 1
0 1 1 1 0
1 0 0 1 0
1 0 1 0 0

Based on the truth table, we can write the logical expression:

$$ a_i = a_i' b_i c_i + a_i b_i' c_i' $$

and:

$$ b_i = a_i' b_i' c_i + a_i' b_i c_i' = a_i' (b_i \oplus c_i) $$

The final result is b, because when the binary bit of b is 1, it means that the number appears only once.

The time complexity is O(n), where n is the length of the array. The space complexity is O(1).

PythonJavaC++GoTypeScriptJavaScriptRust
class Solution: def singleNumber(self, nums: List[int]) -> int: a = b = 0 for c in nums: aa = (~a & b & c) | (a & ~b & ~c) bb = ~a & (b ^ c) a, b = aa, bb return b(code-box)

Solution 3: Set + Math

TypeScriptJavaScript
function singleNumber(nums: number[]): number { const sumOfUnique = [...new Set(nums)].reduce((a, b) => a + b, 0); const sum = nums.reduce((a, b) => a + b, 0); return (sumOfUnique * 3 - sum) / 2; }(code-box)

Solution 4: Bit Manipulation

TypeScriptTypeScript
function singleNumber(nums: number[]): number { let [ans, acc] = [0, 0]; for (const x of nums) { ans ^= x & ~acc; acc ^= x & ~ans; } return ans; }(code-box)

Post a Comment

0Comments

Post a Comment (0)

#buttons=(Accept !) #days=(20)

Our website uses cookies to enhance your experience. Check Now
Accept !