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
numsappears exactly three times except for one element which appears once.
submission
// For detailed explanation, please checkout:
// https://leetcode.com/problems/single-number-ii/solutions/2389678/rust-concise-solution-with-ternary-logic-explained
// https://leetcode.com/problems/single-number-ii/solutions/43295/detailed-explanation-and-generalization-of-the-bitwise-operation-method-for-single-numbers
// or my blog
// I rarely copy paste answer, but this is just awesome.
impl Solution {
pub fn single_number(nums: Vec<i32>) -> i32 {
nums.into_iter()
.fold([0, 0], |[c1, c0], x|
[
c0 & x | c1 & !x,
(c0 ^ x) & !c1
]
)
.into_iter()
.fold(0, |init, val| init | val)
}
}