Algorithm
Polycarp has 26 tasks. Each task is designated by a capital letter of the Latin alphabet.
The teacher asked Polycarp to solve tasks in the following way: if Polycarp began to solve some task, then he must solve it to the end, without being distracted by another task. After switching to another task, Polycarp cannot return to the previous task.
Polycarp can only solve one task during the day. Every day he wrote down what task he solved. Now the teacher wants to know if Polycarp followed his advice.
For example, if Polycarp solved tasks in the following order: "DDBBCCCBBEZ", then the teacher will see that on the third day Polycarp began to solve the task 'B', then on the fifth day he got distracted and began to solve the task 'C', on the eighth day Polycarp returned to the task 'B'. Other examples of when the teacher is suspicious: "BAB", "AABBCCDDEEBZZ" and "AAAAZAAAAA".
If Polycarp solved the tasks as follows: "FFGZZZY", then the teacher cannot have any suspicions. Please note that Polycarp is not obligated to solve all tasks. Other examples of when the teacher doesn't have any suspicious: "BA", "AFFFCC" and "YYYYY".
Help Polycarp find out if his teacher might be suspicious.
The first line contains an integer t (1≤t≤1000). Then t test cases follow.
The first line of each test case contains one integer n (1≤n≤50) — the number of days during which Polycarp solved tasks.
The second line contains a string of length n, consisting of uppercase Latin letters, which is the order in which Polycarp solved the tasks.
For each test case output:
- "YES", if the teacher cannot be suspicious;
- "NO", otherwise.
You may print every letter in any case you want (so, for example, the strings yEs, yes, Yes and YES are all recognized as positive answer).
5 3 ABA 11 DDBBCCCBBEZ 7 FFGZZZY 1 Z 2 AB
NO NO YES YES YES
Code Examples
#1 Code Example with C++ Programming
Code -
C++ Programming
#include<bits/stdc++.h>
#include<string>
using namespace std;
int main(){
int t;
cin>>t;
int n, check;
string s;
while(t--){
cin>>n;
cin>>s;
char s2[n], elem = s[0];
int k = 0;
check = 0;
for(int i = 0; i < n; i++){
if(s[i] != elem){
s2[k] = elem;
elem = s[i];
k++;
}
for(int j = 0; j < k; j++){
if(s[i] == s2[j]){
cout<<"NO"<<endl;
check = 1;
break;
}
}
if(check == 1){
break;
}
}
if(check == 0){
cout<<"YES"<<endl;
}
}
return 0;
}
Copy The Code &
Try With Live Editor
Input
3
ABA
11
DDBBCCCBBEZ
7
FFGZZZY
1
Z
2
AB
Output
NO
YES
YES
YES
Demonstration
Codeforcess solution 1520-A A. Do Not Be Distracted! ,C++, Java, Js and Python,1520-A,Codeforcess solution