Advertisement
Rofyda_Elghadban1

Untitled

Jan 7th, 2024
831
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 3.23 KB | None | 0 0
  1.  #include <bits/stdc++.h>
  2.  #define ll long long
  3.  #define ull unsigned long long
  4.  #define pi 3.141592654
  5.  #define NUM 1e18
  6.  #define Mod  1'000'000'007
  7.  #define fixed(n) fixed<<setprecision(n)
  8.  #define cin(v) for(auto &i:v) cin >> i ;
  9.  #define cout(v) for(auto &i:v) cout << i  <<" ";
  10.  #define vowel(x) (x=='e'||x=='a'||x=='i'||x=='o'||x=='u')
  11.  #define small(x) (x>=97&&x<=122)
  12.  #define capital(x) (x>=65&&x<=90)
  13.  #define Tolower(s) transform(s.begin(),s.end(),s.begin(),::tolower);
  14.  #define Toupper(s) transform(s.begin(),s.end(),s.begin(),::toupper);
  15.  #define sz(x) (int)(x.size())
  16.  #define all(v) ((v).begin()), ((v).end())
  17.  #define allr(v) ((v).rbegin()), ((v).rend())
  18.  #define updmax(a,b) a=max(a,b)
  19.  #define updmin(a,b) a=min(a,b)
  20.  #define ceil(a,b) ((a/b)+(a%b?1:0))
  21.  /* asc -> 1 2 3 ,des -> 3 2 1 */
  22.  
  23.  /***********************************************************************************/
  24.  using namespace std;
  25.  void Rofyda_Elghadban(){
  26.   #ifndef ONLINE_JUDGE  
  27.     freopen("input.txt", "r", stdin), freopen("output.txt", "w", stdout);
  28.    #endif
  29.     ios_base::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr);
  30.  }
  31.  
  32.  void solve(){
  33.   int n,counter=0;
  34.   cin>>n;
  35.   string s;
  36.   cin>>s;
  37.   if(n==1){
  38.     cout<<0<<"\n"<<s<<"\n";
  39.     return;
  40.   }
  41.   if(n==2){
  42.     if(s[0]==s[1]){
  43.       cout<<1<<"\n"<<s[0];
  44.       if(s[0]=='R'){
  45.         cout<<"G"<<"\n";
  46.       }else if(s[0]=='G'){
  47.         cout<<"B"<<"\n";
  48.       }else if(s[0]=='B'){
  49.         cout<<"R"<<"\n";
  50.       }
  51.     }else if(s[0]!=s[1]){
  52.       cout<<0<<"\n"<<s<<"\n";
  53.     }
  54.     return;
  55.   }
  56.   string t="BGR";
  57.   sort(all(t));
  58.   map<int,string>mp;
  59.   string ss=s;
  60.   do{
  61.     if(n%3==0){
  62.       for(int i=0;i<n;i+=3){
  63.         if(s[i]!=t[0]){
  64.           ss[i]=t[0];
  65.           counter++;
  66.         }
  67.         if(s[i+1]!=t[1]&&i+1<n-1){
  68.           ss[i+1]=t[1];
  69.           counter++;
  70.         }
  71.         if(s[i+2]!=t[2]&&i+2<n){
  72.           ss[i+2]=t[2];
  73.           counter++;
  74.         }
  75.       }
  76.     }
  77.     else if(n%3==1){
  78.       for(int i=0;i<n-1;i+=3){
  79.         if(s[i]!=t[0]){
  80.           ss[i]=t[0];
  81.           counter++;
  82.         }
  83.         if(s[i+1]!=t[1]&&i+1<n-2){
  84.           ss[i+1]=t[1];
  85.           counter++;
  86.         }
  87.         if(s[i+2]!=t[2]&&i+2<n-1){
  88.           ss[i+2]=t[2];
  89.           counter++;
  90.         }
  91.       }
  92.       if(s[n-1]!=t[0]){
  93.         ss[n-1]=t[0];
  94.         counter++;
  95.       }
  96.     }
  97.     else if(n%3==2){
  98.       for(int i=0;i<n-2;i+=3){
  99.         if(s[i]!=t[0]){
  100.           ss[i]=t[0];
  101.           counter++;
  102.         }
  103.         if(s[i+1]!=t[1]&&i+1<n-3){
  104.           ss[i+1]=t[1];
  105.           counter++;
  106.         }
  107.         if(s[i+2]!=t[2]&&i+2<n-2){
  108.           ss[i+2]=t[2];
  109.           counter++;
  110.         }
  111.       }
  112.       for(int i=n-2;i<n;i+=2){
  113.         if(s[i]!=t[0]){
  114.           ss[i]=t[0];
  115.           counter++;
  116.         }
  117.         if(s[i+1]!=t[1]&&i+1<n){
  118.           ss[i+1]=t[1];
  119.           counter++;
  120.         }
  121.       }
  122.     }
  123.     mp[counter]=ss;
  124.     ss=s;
  125.     counter=0;
  126.   }while(next_permutation(t.begin(),t.end()));
  127.   for(auto &i:mp){
  128.     cout<<i.first<<"\n"<<i.second<<"\n";
  129.     return;
  130.   }
  131.  }
  132.  
  133.  int main(){
  134.   Rofyda_Elghadban();
  135.   // int t;
  136.   // cin>>t;
  137.   // while(t--){
  138.   //   solve();
  139.   // }
  140.   solve();
  141.   return 0;
  142.  }
  143.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement