Given two positive integers N and K, the task is to find the Kth character of a string obtained by performing the following operation on a string S( initially “A”) N times.
Every ith operation generates following string (Si):
Si = Si – 1 + ‘B’ + rev(comp(Si – 1))
where,
comp() denotes the complement of string i.e., A is changed to B and B is changed to A.
and rev() returns the reverse of a string.
Examples:
Input: N = 3, K = 1
Output: A
Explanation:
Initially, after first operation, S1 = “A”
After 2nd operation, S2 = “ABB”
After 3rd operation, S3 = “ABBBAAB”
The first character of S3 is ‘A’.
Input: N = 2, K = 3
Output: B
Approach: The idea is to use recursion to generate the new string from the previously generated string and to repeat the process until N operations are performed. Below are the steps:
- Initialize two string prev as “A” and curr as an empty string.
- If N = 1 then returns prev otherwise perform below operation.
- Iterate a loop (N – 1) times, each time update curr as prev + “B”.
- Reverse the string prev.
- Again update the string curr string as curr + prev.
- Update string prev as curr.
- After the above steps return the (K – 1)th character of the string curr.
Below is the implementation of the above approach:
C++
#include <bits/stdc++.h>
using namespace std;
char findKthChar( int n, int k)
{
string prev = "A" ;
string cur = "" ;
if (n == 1) {
return 'A' ;
}
for ( int i = 2; i <= n; i++) {
cur = prev + "B" ;
for ( int i = 0;
i < prev.length(); i++) {
if (prev[i] == 'A' ) {
prev[i] = 'B' ;
}
else {
prev[i] = 'A' ;
}
}
reverse(prev.begin(), prev.end());
cur += prev;
prev = cur;
}
return cur[k - 1];
}
int main()
{
int N = 4;
int K = 3;
cout << findKthChar(N, K);
return 0;
}
|
Java
import java.util.*;
class GFG{
static String reverse(String input)
{
char [] a = input.toCharArray();
int l, r = a.length - 1 ;
for (l = 0 ; l < r; l++, r--)
{
char temp = a[l];
a[l] = a[r];
a[r] = temp;
}
return String.valueOf(a);
}
static char findKthChar( int n,
int k)
{
String prev = "A" ;
String cur = "" ;
if (n == 1 )
{
return 'A' ;
}
for ( int j = 2 ; j <= n; j++)
{
cur = prev + "B" ;
for ( int i = 0 ; i < prev.length(); i++)
{
if (prev.charAt(i) == 'A' )
{
prev.replace(prev.charAt(i), 'B' );
}
else
{
prev.replace(prev.charAt(i), 'A' );
}
}
prev = reverse(prev);
cur += prev;
prev = cur;
}
return cur.charAt(k);
}
public static void main(String[] args)
{
int N = 4 ;
int K = 3 ;
System.out.print(findKthChar(N, K));
}
}
|
Python3
def findKthChar(n, k):
prev = "A"
cur = ""
if (n = = 1 ):
return 'A'
for i in range ( 2 , n + 1 ):
cur = prev + "B"
temp1 = [y for y in prev]
for i in range ( len (prev)):
if (temp1[i] = = 'A' ):
temp1[i] = 'B'
else :
temp1[i] = 'A'
temp1 = temp1[:: - 1 ]
prev = "".join(temp1)
cur + = prev
prev = cur
return cur[k - 1 ]
if __name__ = = '__main__' :
N = 4
K = 3
print (findKthChar(N, K))
|
C#
using System;
class GFG{
static String reverse(String input)
{
char [] a = input.ToCharArray();
int l, r = a.Length - 1;
for (l = 0; l < r; l++, r--)
{
char temp = a[l];
a[l] = a[r];
a[r] = temp;
}
return String.Join( "" , a);
}
static char findKthChar( int n,
int k)
{
String prev = "A" ;
String cur = "" ;
if (n == 1)
{
return 'A' ;
}
for ( int j = 2; j <= n; j++)
{
cur = prev + "B" ;
for ( int i = 0; i < prev.Length; i++)
{
if (prev[i] == 'A' )
{
prev.Replace(prev[i], 'B' );
}
else
{
prev.Replace(prev[i], 'A' );
}
}
prev = reverse(prev);
cur += prev;
prev = cur;
}
return cur[k];
}
public static void Main(String[] args)
{
int N = 4;
int K = 3;
Console.Write(findKthChar(N, K));
}
}
|
Javascript
<script>
function reverse(input)
{
let a = input.split( '' );
let l, r = a.length - 1;
for (l = 0; l < r; l++, r--)
{
let temp = a[l];
a[l] = a[r];
a[r] = temp;
}
return a.join( "" );
}
function findKthChar(n, k)
{
let prev = "A" ;
let cur = "" ;
if (n == 1)
{
return 'A' ;
}
for (let j = 2; j <= n; j++)
{
cur = prev + "B" ;
for (let i = 0; i < prev.length; i++)
{
if (prev[i] == 'A' )
{
prev[prev[i]] = 'B' ;
}
else
{
prev[prev[i]] = 'A' ;
}
}
prev = reverse(prev);
cur += prev;
prev = cur;
}
return cur[k];
}
let N = 4;
let K = 3;
document.write(findKthChar(N, K));
</script>
|
Time Complexity: O(N2)
Auxiliary Space: O(1)