An encoded string (s) is given, the task is to decode it. The pattern in which the strings are encoded is as follows.
<count>[sub_str] ==> The substring 'sub_str' appears count times.
Input : str = "1[b]" Output : b Input : str = "2[ab]" Output : abab Input : str = "2[a2[b]]" Output : abbabb Input : str = "3[b2[ca]]" Output : bcacabcacabcaca
The idea is to use two stacks, one for integers and another for characters.
Now, traverse the string,
- Whenever we encounter any number, push it into the integer stack and in case of any alphabet (a to z) or open bracket (‘[‘), push it onto the character stack.
- Whenever any close bracket (‘]’) is encounter pop the character from the character stack until open bracket (‘[‘) is not found in the character stack. Also, pop the top element from the integer stack, say n. Now make a string repeating the popped character n number of time. Now, push all character of the string in the stack.
Below is implementation of this approach:
<!—-Illustration of above code for “3[b2[ca]]”>
This article is contributed by Anuj Chauhan. If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to email@example.com. See your article appearing on the GeeksforGeeks main page and help other Geeks.
Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above.
Attention reader! Don’t stop learning now. Get hold of all the important DSA concepts with the DSA Self Paced Course at a student-friendly price and become industry ready.
- Decode the string encoded with the given algorithm
- Decode an Encoded Base 64 String to ASCII String
- Count occurrences of a substring recursively
- Maximize count of 0s in left and 1s in right substring by splitting given Binary string
- Maximum number of set bits count in a K-size substring of a Binary String
- Decode a median string to the original string
- Count substring of Binary string such that each character belongs to a palindrome of size greater than 1
- Check if a string can become empty by recursively deleting a given sub-string
- Count of binary strings of length N having equal count of 0's and 1's and count of 1's ≥ count of 0's in each prefix substring
- Find if a given string can be represented from a substring by iterating the substring “n” times
- Partition given string in such manner that i'th substring is sum of (i-1)'th and (i-2)'th substring
- Find length of longest subsequence of one string which is substring of another string
- Check if given string is a substring of string formed by repeated concatenation of z to a
- Queries to check if string B exists as substring in string A
- Minimum changes required to make first string substring of second string
- Given a number as a string, find the number of contiguous subsequences which recursively add up to 9
- Given a number as a string, find the number of contiguous subsequences which recursively add up to 9 | Set 2
- Check if the given string is shuffled substring of another string
- Longest substring with count of 1s more than 0s
- Frequency of a substring in a string