[关闭]
@VecMD 2016-07-11T13:12:36.000000Z 字数 543 阅读 1333

CF 676C

  1. #include <cstdio>
  2. #include <cstring>
  3. #include <iostream>
  4. #include <algorithm>
  5. const int maxn = 200007;
  6. char str[maxn];
  7. int pre[maxn][2], n, k;
  8. int cal(int st)
  9. {
  10. int l = 1, ret = 0;
  11. for(int r = 1; r <= n; r ++){
  12. while(l <= n && pre[r][st] - pre[l - 1][st] > k) l++;
  13. ret = std::max(ret, r - l + 1);
  14. }
  15. return ret;
  16. }
  17. int main()
  18. {
  19. std::cin >> n >> k;
  20. std::cin >> str + 1;
  21. int ans = k;
  22. int coa = 0, cob = 0;
  23. for(int i = 1; i <= n; i ++){
  24. if(str[i] == 'a') coa ++;
  25. else cob ++;
  26. pre[i][0] = coa;
  27. pre[i][1] = cob;
  28. }
  29. ans = std::max(cal(0), cal(1));
  30. std::cout << ans << std::endl;
  31. }
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注