首页 > 其他 > 详细

Codeforces Round #650 (Div. 3) C. Social Distance

时间:2020-06-18 01:18:01      阅读:82      评论:0      收藏:0      [点我收藏+]

题目链接:https://codeforces.com/contest/1367/problem/C

题意

给出一个长为 $n$ 的 $01$字符串,两个相邻 $1$ 间距应大于 $k$,初始序列合法,问最多能再使多少 $0$ 变为 $1$ 。

题解

如果当前字符为 $0$,查找 $k$ 个距离内是否有 $1$:

  • 若有则不合法,跳至最近的 $1$
  • 否则因为 $k$ 个距离内没有 $1$,当前字符置为 $1$,跳至第 $i + k$ 个字符

如果当前字符为 $1$,因为初始序列合法,下一个可以置为 $1$ 的 $0$ 至少在第 $i + k$ 个字符后,跳至第 $i + k$ 个字符。

代码

#include <bits/stdc++.h>
using namespace std;

void solve() {
    int n, k; cin >> n >> k;
    string s; cin >> s;
    int ans = 0;
    for (int i = 0; i < s.size(); i++) {
        if (s[i] == 0) {
            int j = i + 1;
            while (j < s.size() and s[j] == 0 and j - i <= k) ++j;
            if (j - i > k or j == s.size()) {
                ans++;
                i += k;
            } else i = j - 1;
        } else i += k;
    }
    cout << ans << "\n";
}

int main() {
    int t; cin >> t;
    while (t--) solve();
}

 

Codeforces Round #650 (Div. 3) C. Social Distance

原文:https://www.cnblogs.com/Kanoon/p/13155297.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!