CF-Codeforces Round #409 (rated, Div. 2, based on VK Cup 2017 Round 2)-A-Vicious Keyboard

ACM模版

描述

描述

题解

一个模拟问题,O(n)解,先查找所有不用置换的VK组合数,然后能够通过一次置换得到VK的组合只有出现连着的两个字符相同,而这里又需要注意的是,两个V相连时,如果再往后接着K那么就不能算是可以置换的,而只能算是一个V+一个不用置换的VK,这样也就 AC 了。这个问题稍微有一些贪心的意味~~~

代码

#include <iostream>
#include <string>

using namespace std;

int main(int argc, const char * argv[])
{
    string s;

    while (cin >> s)
    {
        if (s.length() == 1)
        {
            cout << 0 << '\n';
            continue;
        }

        int res = 0, flag = 0;
        for (int i = 0; i < s.length(); i++)
        {
            if (s[i] == 'V' && s[i + 1] == 'K')
            {
                res++;
                i++;
            }
            else if ((s[i] == 'V' && s[i + 1] == 'V' && s[i + 2] != 'K')
                     || (s[i] == 'K' && s[i + 1] == 'K'))
            {
                flag = 1;
                i++;
            }
        }
        if (flag)
        {
            res++;
        }
        cout << res << '\n';
    }

    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值