Back to all solutions
#3191 - Minimum Operations to Make Binary Array Elements Equal to One I
Problem Description
You are given a binary array nums.
You can do the following operation on the array any number of times (possibly zero):
- Choose any 3 consecutive elements from the array and flip all of them.
Flipping an element means changing its value from 0 to 1, and from 1 to 0.
Return the minimum number of operations required to make all elements in nums equal to 1.
If it is impossible, return -1.
Solution
/**
* @param {number[]} nums
* @return {number}
*/
var minOperations = function(nums) {
const result = [...nums];
let operations = 0;
for (let i = 0; i < nums.length - 2; i++) {
if (result[i] === 0) {
result[i] ^= 1;
result[i + 1] ^= 1;
result[i + 2] ^= 1;
operations++;
}
}
return result.every(num => num === 1) ? operations : -1;
};