给我们一个数组arr [],它只包含0和1。目标是对arr []的所有子数组进行计数,以使0和1的出现总数相等。如果数组为[1,0,0]。子数组将仅为[1,0]。
让我们通过示例来理解。
输入− arr [] = {0,0,1,1,1,0};
输出-等于1和0的子数组数为-4
说明-Subaarays将是-
arr[0 to 3] = [0,0,1,1], arr[1 to 2] = [0,1], arr[4 to 5] =[1,0], Arr[0 to 5] =[0,0,1,1,1,0].
输入− arr [] = {0,1,1,1,1};
输出-等于1和0的子数组数为-1
说明-Subaarays将为-arr [0至1] = [0,1]
我们将使用两个for循环遍历数组,以生成所有可能的子数组。从i = 0到i <= size-1,从j = i到j <= size-1。形成的子数组将在arr [i]至arr [j]之间。在每个子数组中计数0和1的频率。如果相等,则增加计数。
取数字的数组arr []。
函数sub_zeroes_ones(int arr [],int size)获取数组,并返回等于no的子数组的计数。的0和1。
将初始计数设为0。
我们将使用两个for循环遍历数组,这些循环从i = 0到i <= size-1,从j = 0到j <= size-1。
对于子数组arr [i]至arr [j]中的0和1,将两个变量total_0,total_1设为0。
比较arr [j]与0和1。如果arr [j]为0或1,则递增各自的计数(total_0或total_1)。
如果total_0 == total_1。增量计数。(子数组与元素具有相同数量的0和1)。
在两个循环的最后,返回count作为结果。
#include <bits/stdc++.h> using namespace std; int sub_zeroes_ones(int arr[], int size){ int count = 0; for (int i = 0; i <= size - 1; i++){ int total_0 = 0; int total_1 = 0; for (int j = i; j <= size - 1; j++){ if (arr[j] == 0){ total_0++; } else if (arr[j] == 1){ total_1++; } if(total_0 == total_1){ count++; } } } return count; } int main(){ int arr[] = {0, 1, 1, 0, 0}; int size = sizeof(arr)/sizeof(arr[0]); cout<<"Count of subarrays with equal number of 1’s and 0’s are: "<<sub_zeroes_ones(arr, size); }
输出结果
如果我们运行上面的代码,它将生成以下输出-
Count of subarrays with equal number of 1’s and 0’s are: 4