Table of Contents
ExampleExample
Explanation
Approach
Example
Output
in conclusion
Home Backend Development C++ Maximize the number of 0s to flip in a given binary array such that there are at least K 0s between two 1s

Maximize the number of 0s to flip in a given binary array such that there are at least K 0s between two 1s

Aug 26, 2023 pm 07:49 PM
binary array Maximize the number of flips between

Maximize the number of 0s to flip in a given binary array such that there are at least K 0s between two 1s

A binary array is a special type of array that contains only the numbers 0 and 1. In this problem, we are given a binary array and an integer K. Our task is to calculate the maximum number of 0's that can be flipped into 1's in a given binary array such that there are at least K 0's between two 1's.

ExampleExample

Input 1: arr[] = { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0 },  K = 2
Copy after login
Output 1: yes
Copy after login
The Chinese translation of

Explanation

is:

Explanation

The 3rd and 6th indexes in the above array are the only valid indexes and can be flipped to ensure that there are at least 2 0s between the two 1s. Therefore, the resulting array is {1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0}

Input 2: arr[] = {0, 1, 0, 0, 0, 1}, k = 1
Copy after login
Output 2: 1
Copy after login
The Chinese translation of

Explanation

is:

Explanation

The 3rd index of the above array is the only valid flip index.

Approach

We have seen the examples given above with arrays and integers k, let us move on to the method −

The idea of ​​this method is to count the number of consecutive 0s between two 1s, and check whether it is suitable to flip some 0s to 1s between them. Suppose there are X zeros between two ones. According to observation, the number of 0s that can be flipped is (X-K) / (K 1). So, iterate through the array and record how many consecutive 0's there are between each pair of 1's. Then, add the number of 0s that can be flipped to the variable count, which is the desired response.

Let us discuss the following method step by step -

  • First we will create a function called 'onesCount' which will take the given array 'arr' and integer 'K' as parameters and return the required integer 'count' value returned.

  • Create variables count and lastIdx.

  • Initialize the variable count with 0, which is used to store the count of fillip 0s.

  • Initialize the variable lastIdx using (-(K 1)) to store the last index in the array with a value of 1.

  • Use a for loop to iterate through the array, check if the current element is 1, and then verify if there are enough 0s between two consecutive 1s to add another 1. Finally, update the index value of the last 1.

  • Write a condition that calculates the last segment of 0 in the array and adds it to the variable count.

  • Finally, our final answer count is returned.

The Chinese translation of

Example

is:

Example

The following is a C program for calculating the maximum conversion of 0s into 1s to ensure that there are at least k 0s between two 1s.

#include <bits/stdc++.h>
using namespace std; 
// Function to find the count of the maximum number of 0s to be filliped 
int onesCount(int arr[], int n, int k){
   int count = 0; // Stores the count of 1's 
   int lastIdx = -(k + 1); // Stores the last index of value 1 
   
   // Traverse the array using for loop
   for (int i = 0; i < n; i++) { 
      // If the current element is 1
      if (arr[i] == 1) { 
      
         // Verify whether there are enough 0s between two consecutive 1s to add another 1 in between them.
         if (i - lastIdx - 1 >= 2 * (k - 1)) {
            count += (i - lastIdx - 1 - k) / (k + 1);
         } 
         lastIdx = i; // Update the last index of the value 1 of the array
      }
   } 
   
   // condition to include the last section of 0s in the array
   count += (n - lastIdx - 1) / (k + 1);
 
   // Return the answer
   return count;
} 
int main(){
   int arr[] = { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0 }; // given array
   int N = sizeof(arr) / sizeof(arr[0]); //getting size of an array
   int K = 2; //given integer 
   
   // Call the function
   int result = onesCount(arr, N, K);    
   cout<< "The count of Maximum filliped of 0's is "<< result ;
   return 0;
}
Copy after login

Output

The Count of Maximum filliped of 0's is 2
Copy after login

Time and space complexity

The time complexity of the above code is O(N) because we only traverse the array. where N is the size of the given array.

The space complexity of the above code is O(1) because we are not using any extra space.

in conclusion

In this tutorial, we implemented a program to find the maximum number of 0s to flip in a given binary array so that there are at least K 0s between two 1s. This problem is solved by counting the number of consecutive zeros between two 1's and checking if it is suitable to flip some zeros between them. The time complexity is O(N) and the space complexity is O(1). where N is the size of the string.

The above is the detailed content of Maximize the number of 0s to flip in a given binary array such that there are at least K 0s between two 1s. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

C language data structure: data representation and operation of trees and graphs C language data structure: data representation and operation of trees and graphs Apr 04, 2025 am 11:18 AM

C language data structure: The data representation of the tree and graph is a hierarchical data structure consisting of nodes. Each node contains a data element and a pointer to its child nodes. The binary tree is a special type of tree. Each node has at most two child nodes. The data represents structTreeNode{intdata;structTreeNode*left;structTreeNode*right;}; Operation creates a tree traversal tree (predecision, in-order, and later order) search tree insertion node deletes node graph is a collection of data structures, where elements are vertices, and they can be connected together through edges with right or unrighted data representing neighbors.

The truth behind the C language file operation problem The truth behind the C language file operation problem Apr 04, 2025 am 11:24 AM

The truth about file operation problems: file opening failed: insufficient permissions, wrong paths, and file occupied. Data writing failed: the buffer is full, the file is not writable, and the disk space is insufficient. Other FAQs: slow file traversal, incorrect text file encoding, and binary file reading errors.

How do I use rvalue references effectively in C  ? How do I use rvalue references effectively in C ? Mar 18, 2025 pm 03:29 PM

Article discusses effective use of rvalue references in C for move semantics, perfect forwarding, and resource management, highlighting best practices and performance improvements.(159 characters)

What are the basic requirements for c language functions What are the basic requirements for c language functions Apr 03, 2025 pm 10:06 PM

C language functions are the basis for code modularization and program building. They consist of declarations (function headers) and definitions (function bodies). C language uses values ​​to pass parameters by default, but external variables can also be modified using address pass. Functions can have or have no return value, and the return value type must be consistent with the declaration. Function naming should be clear and easy to understand, using camel or underscore nomenclature. Follow the single responsibility principle and keep the function simplicity to improve maintainability and readability.

How do I use ranges in C  20 for more expressive data manipulation? How do I use ranges in C 20 for more expressive data manipulation? Mar 17, 2025 pm 12:58 PM

C 20 ranges enhance data manipulation with expressiveness, composability, and efficiency. They simplify complex transformations and integrate into existing codebases for better performance and maintainability.

How to calculate c-subscript 3 subscript 5 c-subscript 3 subscript 5 algorithm tutorial How to calculate c-subscript 3 subscript 5 c-subscript 3 subscript 5 algorithm tutorial Apr 03, 2025 pm 10:33 PM

The calculation of C35 is essentially combinatorial mathematics, representing the number of combinations selected from 3 of 5 elements. The calculation formula is C53 = 5! / (3! * 2!), which can be directly calculated by loops to improve efficiency and avoid overflow. In addition, understanding the nature of combinations and mastering efficient calculation methods is crucial to solving many problems in the fields of probability statistics, cryptography, algorithm design, etc.

How do I use move semantics in C   to improve performance? How do I use move semantics in C to improve performance? Mar 18, 2025 pm 03:27 PM

The article discusses using move semantics in C to enhance performance by avoiding unnecessary copying. It covers implementing move constructors and assignment operators, using std::move, and identifies key scenarios and pitfalls for effective appl

How does dynamic dispatch work in C   and how does it affect performance? How does dynamic dispatch work in C and how does it affect performance? Mar 17, 2025 pm 01:08 PM

The article discusses dynamic dispatch in C , its performance costs, and optimization strategies. It highlights scenarios where dynamic dispatch impacts performance and compares it with static dispatch, emphasizing trade-offs between performance and

See all articles