所以以前是什么思路
// #include <cstddef>
// #include <cstdio>
// #include <string>
// using namespace std;
// // 4j d5gf 4ji4klfgf0j84ekb9udg9ol53l 0k9 dd39llkg8j kj j ll kk jlgnnl03uk gk5gj034fjjkk3
// // 现在程序的问题是只能识别空格首字母为数字的情况,然后忽略它;如果是其他空格类型,单单一个str[i+1]不足以定位到第一个下一个单词开头字符
// int main() {
// char buf[200];
// while (fgets(buf, 200, stdin) != NULL) {
// string str = buf;
// str.erase(str.size() - 1);
// for (unsigned i = 0; i < str.size(); ++i) {
// // 首位默认大写,如果是数字,则忽略
// if (0 == i) {
// if (str[i] >= 48 && str[i] <= 57) {
// continue;
// }
// else {
// str[i] -= 32;
// }
// }
// // 空白符包括:空格(' ')、制表符('\t')、回车符('\r')、换行符('\n')
// if (str[i] == ' ' || str[i] == '\t' || str[i] == '\r' || str[i] == '\n') {
// // 48-57是ASCII码中0-9
// // 原来的bug是,如果遇到不止一个空格,那么i+1后变成32
// // 就会进入下面的while循环,又减去32变成0,对应在ASCII码表上已经没有字符了,对应的是NULL
// // if (str[i + 1] >= 48 && str[i + 1] <= 57) {
// // continue;
// // }
// // else {
// // str[i + 1] -= 32;
// // }
// // 正确做法是只有是字母才用减去32,空格是最小的,直接与ASCII数值比较可以直接略过空格
// if (str[i + 1] >= 'a' && str[i + 1] <= 'z') {
// str[i + 1] -= 32;
// }
// }
// }
// printf("%s\n", str.c_str());
// }
// return 0;
// }
#include <string>
#include <iostream>
#include <vector>
using namespace std;
int main() {
string s;
while (getline(cin, s)) {
for (int i = 0; i < s.size(); i++) {
if (s[i] >= 'a' && s[i] <= 'z') {
if (i == 0 || s[i - 1] == ' ' || s[i - 1] == '\t' || s[i - 1] == '\r' || s[i - 1] == '\n') {
s[i] -= 32;
}
}
}
cout << s << endl;
}
return 0;
}

京公网安备 11010502036488号