- Data Structures & Algorithms
- DSA - Home
- DSA - Overview
- DSA - Environment Setup
- Algorithm
- DSA - Algorithms Basics
- DSA - Asymptotic Analysis
- DSA - Greedy Algorithms
- DSA - Divide and Conquer
- DSA - Dynamic Programming
- Data Structures
- DSA - Data Structure Basics
- DSA - Data Structures and Types
- DSA - Array Data Structure
- Linked Lists
- DSA - Linked List Basics
- DSA - Doubly Linked List
- DSA - Circular Linked List
- Stack & Queue
- DSA - Stack
- DSA - Expression Parsing
- DSA - Queue
- Searching Techniques
- DSA - Linear Search
- DSA - Binary Search
- DSA - Interpolation Search
- DSA - Hash Table
- Sorting Techniques
- DSA - Sorting Algorithms
- DSA - Bubble Sort
- DSA - Insertion Sort
- DSA - Selection Sort
- DSA - Merge Sort
- DSA - Shell Sort
- DSA - Quick Sort
- Graph Data Structure
- DSA - Graph Data Structure
- DSA - Depth First Traversal
- DSA - Breadth First Traversal
- Tree Data Structure
- DSA - Tree Data Structure
- DSA - Tree Traversal
- DSA - Binary Search Tree
- DSA - AVL Tree
- DSA - Red Black Trees
- DSA - B Trees
- DSA - B+ Trees
- DSA - Splay Trees
- DSA - Spanning Tree
- DSA - Tries
- DSA - Heap
- Recursion
- DSA - Recursion Basics
- DSA - Tower of Hanoi
- DSA - Fibonacci Series
- DSA Useful Resources
- DSA - Questions and Answers
- DSA - Quick Guide
- DSA - Useful Resources
- DSA - Discussion
Maximum Number of 0s Placed Consecutively at the Start and End in any Rotation of a Binary String
Binary string means the string contains only two types of char either 1 or 0. It is known as base 2. In this problem, we have given a binary string str and also the size of the string 'n'. Our task is to find the maximum number of zeros places consecutively at the start and end of any rotation of a binary string. Let's see examples with explanations below to understand the problem in a better way.
Sample Example
Input 1
str = “101001, n = 6
Output 1
2
Explanation
The string can be rotated in any of the following possible ways:
"101001", The number of 0s in the string's beginning is 0, while its ending is 0. Total = 0+0 = 0
"110100", The number of 0s in the string's beginning is 0, while its ending is 2. Total = 0+2 = 2
"011010", The number of 0s in the string's beginning is 1, while its ending is 1. Total = 1+1 = 2
"001101", The number of 0s in the string's beginning is 2, while its ending is 0. Total = 2+0 = 2
"100110", The number of 0s in the string's beginning is 0, while its ending is 1. Total = 0+1 = 1
"010011", The number of 0s in the string's beginning is 1, while its ending is 0. Total = 1+0 = 1
Since the maximum possible zeros are 2.
Input 2
str = “1100”, k = 4
Output 2
2
Approaches
We have seen the example above for the given string of size n, let us move to the approaches:
Approach 1: Naive Approach
The concept is simple to produce all possible rotations of the given string and check each string, count the number of zeros placed consecutively at the begning and ending of the string. Maintain the maximum cout of 0's in the variable 'cnt' and return that count.
Example
Let's see the code below for a better understanding of the above approach.
#include <bits/stdc++.h> using namespace std; // Create a function to count maximum consecutive 0's at the beginning and ending in any rotation of binary string int maxZeros(string str, int n){ // Verify that the string contains only 0s as characters. int cnt = 0; // traverse the string to check all the char of the string are 0's or not for (int i = 0; i < n; i++) { if (str[i] == '0') cnt++; } // check the count of 0's equal to the size of the string if (cnt == n) { return cnt; } string sstr = str + str; //extended string with itself cnt = 0; //reset the count equal to 0 // Create all possible string rotations. for (int i = 0; i < n; i++) { int cnts = 0; //0's at start int cnte = 0; //0's at end // for the beginning zeroes for (int j = i; j < i + n; ++j) { if (sstr[j]=='0') cnts++; else break; } // for the ending zeroes for (int j = i + n - 1; j >= i; j--) { if (sstr[j]=='0') cnte++; else break; } // get maximum 0's cnt = max(cnt, cnts+cnte); } // return maximum cout of the 0's return cnt; } int main(){ string str = "101001"; // given string cout << "Input String: " << str << endl; int n = 6; //size of the string int maxZerosCount = maxZeros(str, n); cout << "Maximum number of 0s placed consecutively at the start and end in any rotation of a Binary String: "; cout<<maxZerosCount; // Print maximum cout of the 0's return 0; }
Output
Input String: 101001 Maximum number of 0s placed consecutively at the start and end in any rotation of a Binary String: 2
Time and Space Complexity
The time complexity is O(N^2). The space complexity is O(N). Here N is the size of the string
Approach 2: Consecutive zero's
The idea is simple to calculate consecutive zero's for the given string and count the zeros placed consecutively in the string at the start and end. Maintain the maximum cout of 0's in the variable 'cnt' and return that count.
Example
Let's see the code below for a better understanding of the above approach.
#include <bits/stdc++.h> using namespace std; // Create a function to count maximum consecutive 0's at the beginning and ending in any rotation of binary string int maxZeros(string str, int n){ // Verify that the string contains only 0s as characters. int cnt = 0; // Traverse string to check if all the chars of the string are 0's or not for (int i = 0; i < n; i++) { if (str[i]=='0') cnt++; } // check the count of 0's equal to the size of the string if (cnt == n) { return cnt; } cnt = 0; //reset the count equal to 0 int tempcnt = 0; for (int i = 0; i < n; i++) { if (str[i]=='0') tempcnt++; else { cnt = max(cnt, tempcnt); tempcnt = 0; } } // get maximum count cnt = max(cnt, tempcnt); // For 0's present at the end and // beginning of the string int s = 0, e = n - 1; tempcnt = 0; // for start while (str[s] != '1' && s < n) { tempcnt++; s++; } // for end while (str[e] != '1' && e >= 0) { tempcnt++; e--; } // get maximum 0's cnt = max(cnt, tempcnt); // return maximum cout of the 0's return cnt; } int main(){ string str = "101001"; // given string cout << "Input String: " << str << endl; int n = 6; //size of the string int maxZerosCount = maxZeros(str, n); cout << "Maximum number of 0s placed consecutively at the start and end in any rotation of a Binary String: "; cout<<maxZerosCount; // print maximum cout of the 0's return 0; }
Output
Input String: 101001 Maximum number of 0s placed consecutively at the start and end in any rotation of a Binary String: 2
Time and Space Complexity
The time complexity: O(N), Where N is the size of the string. The space complexity: O(1)
Conclusion
In this tutorial, we have implemented a program to find the Maximum number of 0s placed consecutively at the start and end of any rotation of a Binary String. We have implemented two approaches: naive and efficient. Naive approach with time complexity O(N^2) and space complexity O(N). Efficient approach with time complexity O(N) and space complexity O(1).
- Related Articles
- JavaScript Program to Find Maximum number of 0s placed consecutively at the start and end in any rotation of a Binary String
- Removing 0s from start and end - JavaScript
- How to match text at the start or end of a string in Python?
- Match any string with p at the end of it.
- Encoding a number string into a string of 0s and 1s in JavaScript
- Program to find number m such that it has n number of 0s at end in Python
- Maximize partitions in a given Binary String having the same ratio of 0s and 1s
- Check if the binary representation of a number has equal number of 0s and 1s in blocks in Python
- Python program to find start and end indices of all Words in a String
- Maximum number of characters between any two same character in a string in C
- How to remove dot and number at the end of the string in an R vector?
- Maximum difference of zeros and ones in binary string in C++
- JavaScript Program for Left Rotation and Right Rotation of a String
- Java Program for Left Rotation and Right Rotation of a String
- C++ Program for Left Rotation and Right Rotation of a String