Problem
Alice and Bob are playing a game. They have a common string of length . The players also have their individual strings (belonging to Alice) and (belonging to Bob) which are empty in the beginning. Game begins with Alice and both players take alternate turns.
In her/his turn, the player picks a single character from string , adds it to the end of their individual string and deletes the picked character from string .
The game continues until string is empty. Find whether there exists a sequence of moves such that the strings and are same at the end of the game.
Input Format
- The first line of input will contain a single integer , denoting the number of test cases.
- Each test case consists of multiple lines of input.
- The first line of each test case contains an integer — the length of the string.
- The next line contains the strings consisting of lowercase english alphabets.
Output Format
For each test case, output on a new line, YES
if there exists a sequence of moves such that the strings and are same at the end of the game, and NO
otherwise.
You may print each character of the string in uppercase or lowercase (for example, the strings YES
, yEs
, yes
, and yeS
will all be treated as identical).
Constraints
- consists of lowercase english alphabets
- The sum of over all test cases does not exceed .
Sample 1:
4 4 abab 5 cbcba 4 abcd 6 pqprqr
YES NO NO YES
Explanation:
Test case : Consider the following sequence of moves:
- Alice picks the first character of string and adds it to the end of string . Thus, becomes
bab
and becomesa
. - Bob picks the second character of string and adds it to the end of string . Thus, the strings are
bb
,a
, anda
. - Alice picks the second character of string and adds it to the end of string . Thus, the strings are
b
,ab
, anda
. - Bob picks the first character of string and adds it to the end of string . Thus, becomes empty,
ab
, andab
.
We can see that using this sequence of moves, the final strings and are equal.
Test case : There exists no sequence of moves such that the strings and become equal in the end.
Test case : There exists no sequence of moves such that the strings and become equal in the end.
Test case : Consider the following sequence of moves:
- Alice picks the first character of string and adds it to the end of string . Thus, becomes
qprqr
and becomesp
. - Bob picks the second character of string and adds it to the end of string . Thus, the strings are
qrqr
,p
, andp
. - Alice picks the second character of string and adds it to the end of string . Thus, the strings are
qqr
,pr
, andp
. - Bob picks the third character of string and adds it to the end of string . Thus, becomes
qq
, becomespr
, and becomespr
. - Alice picks the second character of string and adds it to the end of string . Thus, the strings are
q
,prq
, andpr
. - Bob picks the first character of string and adds it to the end of string . Thus, becomes empty,
prq
, andprq
.
We can see that using this sequence of moves, the final strings and are equal.
Code(c++):-
Recommended Post :-
- Swap the adjacent characters of the string
- Double the vowel characters in the string
- Character with their frequency
- Program to find the closest value
- Swap adjacent characters
- Double the vowel characters
- Check valid parenthesis
- Print the characters with their frequencies
- Find closest value
- Word Count
- Program of CaesarCipher
- Program to find the perfect city
- Annual Day | Tech Mahindra coding question
- Find the number of pairs in the array whose sum is equal to a given target.
Full C course:-
Key points:-
- How to set limit in the floating value in python
- What is boolean data type
- How to print any character without using format specifier
- How to check that given number is power of 2 or not
- How to fix limit in double and floating numbers after dot (.) in c++
- How to print a double or floating point number in scientific notation and fixed notation
- How to take input a string in c
- How to reduce the execution time of program in c++.
Cracking the coding interview:-
Array and string:-
Tree and graph:-
Hackerearth Problems:-
- Very Cool numbers | Hacker earth solution
- Vowel Recognition | Hackerearth practice problem solution
- Birthday party | Hacker earth solution
- Most frequent | hacker earth problem solution
- program to find symetric difference of two sets
- cost of balloons | Hacker earth problem solution
- Chacha o chacha | hacker earth problem solution
- jadu and dna | hacker earth solution
- Bricks game | hacker earth problem
- Anti-Palindrome strings | hacker earth solution
- connected components in the graph | hacker earth data structure
- odd one out || hacker earth problem solution
- Minimum addition | Hackerearth Practice problem
- The magical mountain | Hackerearth Practice problem
- The first overtake | Hackerearth Practice problem
- Playing With Characters | Hackerrank practice problem solution
- Sum and Difference of Two Numbers | hackerrank practice problem solution
- Functions in C | hackerrank practice problem solution
- Pointers in C | hackerrank practice problem solution
- Conditional Statements in C | Hackerrank practice problem solution
- For Loop in C | hackerrank practice problem solution
- Sum of Digits of a Five Digit Number | hackerrank practice problem solution
- 1D Arrays in C | hackerrank practice problem solution
- Array Reversal | hackerrank practice problem solution
- Printing Tokens | hackerrank practice problem solution
- Digit Frequency | hackerrank practice problem solution
- Calculate the Nth term | hackerrank practice problem solution
Data structure:-
- Program to find cycle in the graph
- Implementation of singly link list
- Implementation of queue by using link list
- Algorithm of quick sort
- stack by using link list
- program to find preorder post order and inorder of the binary search tree
- Minimum weight of spanning tree
- Preorder, inorder and post order traversal of the tree
MCQs:-
0 Comments