题目描述
小红拿到了一个字符串,她准备将一些字母变成白色,变成白色的字母看上去就和空格一样,这样字符串就变成了一些单词。
现在小红希望,每个单词都满足以下两种情况中的一种:
1.开头第一个大写,其余为小写(长度为 1 的大写字母也是合法的)。
2.所有字符全部是小写。
小红想知道,最少需要将多少字母变成白色?
输入描述:
一个仅包含大小写字母的字符串。
字符串长度不超过200000
输出描述:
将字母变成白色的最小数量。
输入
aDRRanko
输出
2
说明
将第二个和第三个字母变成白色即可,字符串变成 "a Ranko"
#include<iostream>
#include<bits/stdc++.h>
using namespace std;
#define long long ll;
int main()
{ios::sync_with_stdio(0);cin.tie(0),cout.tie(0);string s;cin>>s;int n=s.length();int i;int count=0;for(i=n-1;i>=0;i--){if(islower(s[i]))continue;else{if(i){count++;s[i-1]='a';i--;}}}cout<<count;
}