2275 - Largest Combination With Bitwise AND Greater Than Zero (Medium)
Problem Link
https://leetcode.com/problems/largest-combination-with-bitwise-and-greater-than-zero
Problem Statement
The bitwise AND of an array nums is the bitwise AND of all integers in nums.
- For example, for
nums = [1, 5, 3], the bitwise AND is equal to1 & 5 & 3 = 1. - Also, for
nums = [7], the bitwise AND is7.
You are given an array of positive integers candidates. Evaluate the bitwise AND of every combination of numbers of candidates. Each number in candidates may only be used once in each combination.
Return the size of the largest combination of candidates with a bitwise AND greater than 0.
Example 1:
Input: candidates = [16,17,71,62,12,24,14]
Output: 4
Explanation: The combination [16,17,62,24] has a bitwise AND of 16 & 17 & 62 & 24 = 16 > 0.
The size of the combination is 4.
It can be shown that no combination with a size greater than 4 has a bitwise AND greater than 0.
Note that more than one combination may have the largest size.
For example, the combination [62,12,24,14] has a bitwise AND of 62 & 12 & 24 & 14 = 8 > 0.
Example 2:
Input: candidates = [8,8]
Output: 2
Explanation: The largest combination [8,8] has a bitwise AND of 8 & 8 = 8 > 0.
The size of the combination is 2, so we return 2.
Constraints:
1 <= candidates.length <= 10^51 <= candidates[i] <= 10^7
Approach 1: Counting
If the -th bit is set after performing AND operation on candidates, it means the -th of all candidates must be 1. Therefore, we check each bit to see which bit has the most candidates with the bit set.
class Solution {
public:
int largestCombination(vector<int>& candidates) {
int n = candidates.size(), ans = 0;
for (int i = 0; i < 32; i++) {
// init bits to 0 for each index
int bits = 0;
// iterate each candidate
for (int j = 0; j < n; j++) {
// i-th bit is set for candidates[j]
if ((1 << i) & candidates[j]) {
// count the bit
bits += 1;
}
}
// update the ans
ans = max(ans, bits);
}
return ans;
}
};