Given a binary array nums, you should delete one element from it.
Return the size of the longest non-empty subarray containing only 1’s in the resulting array. Return 0 if there is no such subarray.
?
Input: nums = [1,1,0,1]
Output: 3
Explanation: After deleting the number in position 2, [1,1,1] contains 3 numbers with value of 1’s.
Input: nums = [0,1,1,1,0,1,1,0,1]
Output: 5
Explanation: After deleting the number in position 4, [0,1,1,1,1,1,0,1] longest subarray with value of 1’s is [1,1,1,1,1].
Input: nums = [1,1,1]
Output: 2
Explanation: You must delete one element.
From: LeetCode
Link: 1493. Longest Subarray of 1’s After Deleting One Element
int longestSubarray(int* nums, int numsSize) {
int max_len = 0;
int curr_len = 0;
int prev_len = 0;
for (int i = 0; i < numsSize; i++) {
if (nums[i] == 1) {
curr_len++;
} else {
max_len = (prev_len + curr_len > max_len) ? prev_len + curr_len : max_len;
prev_len = curr_len + 1; // Include the current 0 as it could be deleted
curr_len = 0;
}
}
max_len = (prev_len + curr_len > max_len) ? prev_len + curr_len : max_len;
// Since we need to delete one element, subtract 1, except when the array is all 1s
return (numsSize != curr_len) ? max_len - 1 : numsSize - 1;
}