Advertisement
Guest User

Untitled

a guest
Mar 30th, 2020
123
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 0.95 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2. const int maxN = 1e6 + 1;
  3. using namespace std;
  4.  
  5. int sap[maxN], ngua[maxN];
  6.  
  7. int main()
  8. {
  9.     int n,k;
  10.     string s;
  11.     cin >> n >> k;
  12.     cin >> s;
  13.  
  14.     s = " " + s;
  15.  
  16.     fill(ngua, ngua + maxN, 0);
  17.     fill(sap, sap + maxN, 0);
  18.     if(s[1] == 'O') ngua[1] = 1;
  19.     else sap[1] = 1;
  20.     for(int i = 1; i <= n; ++i)
  21.     {
  22.         if(s[i] == 'O')
  23.             ngua[i] = ngua[i - 1] + 1;
  24.         else
  25.             ngua[i] = ngua[i - 1];
  26.         if(s[i] == 'R')
  27.             sap[i] = sap[i - 1] + 1;
  28.         else
  29.             sap[i] = sap[i - 1];
  30.     }
  31.  
  32.     int ans;
  33.  
  34.     int tmp = n/(k+1) * (k+1);
  35.  
  36.     for(int kc = tmp; kc >= 1; kc -= (k+1))
  37.     {
  38.         for(int i = 1; i <= n - kc + 1; ++i)
  39.         {
  40.             if((ngua[i+kc-1] - ngua[i-1]) == k * (sap[i+kc-1] - sap[i-1]))
  41.             {
  42.                 ans = kc;
  43.                 goto xyz;
  44.             }
  45.         }
  46.     }
  47.  
  48. xyz:   cout << ans << endl;
  49. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement