题目描述
对一个字符串中的所有单词,如果单词的首字母不是大写字母,则把单词的首字母变成大写字母。 在字符串中,单词之间通过空白符分隔,空白符包括:空格(’ ‘)、制表符(’\t’)、回车符(’\r’)、换行符(’\n’)。
输入描述:
输入一行:待处理的字符串(长度小于100)。
输出描述:
可能有多组测试数据,对于每组数据,
输出一行:转换后的字符串。
示例1
输入
if so, you already have a google account. you can sign in on the right.
输出
If So, You Already Have A Google Account. You Can Sign In On The Right.
题目解析:无
代码:
#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<string.h>
#include<iomanip>
#include<map>
#include<set>
#include<vector>
//在str中搜索所有的flag下标。for((index=str.find(flag,index))!= string::npos) index++;
using namespace std;
int main(){
string sentence;
while(getline(cin,sentence)){
int len = sentence.size();
for(int i = 0 ; i < len - 1 ; i++){
if(i == 0){
if(sentence[i] >= 'a' && sentence[i] <= 'z'){
sentence[i] = sentence[i] - 32;
}
}else{
if(sentence[i] == ' ' || sentence[i] == '\t' || sentence[i] == '\r' || sentence[i] == '\n'){
if(sentence[i+1] >= 'a' && sentence[i+1] <= 'z'){
sentence[i+1] = sentence[i+1] - 32;
}
}
}
}
cout << sentence << endl;
}
return 0;
}