时间限制:1.000S 空间限制:32MB
题目描述
输出一个词组中每个单词的首字母的大写组合。
输入描述
输入的第一行是一个整数n,表示一共有n组测试数据。(输入只有一个n,没有多组n的输入)
接下来有n行,每组测试数据占一行,每行有一个词组,每个词组由一个或多个单词组成;每组的单词个数不超过10个,每个单词有一个或多个大写或小写字母组成;
单词长度不超过10,由一个或多个空格分隔这些单词。
输出描述
请为每组测试数据输出规定的缩写,每组输出占一行。
输入示例
1
ad dfa fgs
输出示例
ADF
提示信息
注意:单词之间可能有多个空格
代码示例
#include <iostream>
#include <string>
using namespace std;
int main(){
int n;
cin >> n;
getchar();//吸收一个回车符,因为输入n之后要输入一个回车
string s;
while(n--)
{
getline(cin,s);//接受新的一行
string result;
//如果首字母是小写,则换成大写
if(s[0]>='a'&&s[0]<='z')
{
s[0]-=32;
}
//将首字母拼接到结果集中
result+=s[0];
//遍历整个字符串
for(int i=1; i<s.size()-1;i++)
{
//如果当前字符是空格,下一个字符不是空格,说明下一个字符是新单词的首字母
if(s[i]==' '&&s[i+1]!=' ')
{
//判定新单词的首字母是否是小写,小写则转换成大写
if(s[i+1]>='a'&&s[i+1]<='z')
s[i+1]-=32;
//将新单词首字母拼接到结果中
result+=s[i+1];
}
}
cout << result <<endl;
}
return 0;
}
代码示例2(函数)
#include <iostream>
#include <string>
using namespace std;
char changechar(char a)
{
if(a>='a'&&a<='z')
a-=32;
return a;
}
int main(){
int n;
cin >> n;
getchar();//吸收一个回车符,因为输入n之后要输入一个回车
string s;
while(n--)
{
getline(cin,s);//接受新的一行
string result;
//将首字母拼接到结果集中
result+=changechar(s[0]);//将s[0]传递到参数进行处理,转换成大写字母
//遍历整个字符串
for(int i=1; i<s.size()-1;i++)
{
//如果当前字符是空格,下一个字符不是空格,说明下一个字符是新单词的首字母
if(s[i]==' '&&s[i+1]!=' ')
{
//将新单词首字母拼接到结果中
result+=changechar(s[i+1]);//将s[i+1]传递到参数进行处理,转换成大写字母
}
}
cout << result <<endl;
}
return 0;
}