【题目链接】
ybt 1139:整理药名
OpenJudge NOI 1.7 15:整理药名
【题目考点】
1. 字符串处理
2. ASCII码
- 大小写判断
- 判断一个字符c是不是大写字母:
c >= 'A' && c <= 'Z'
或isupper(c)
- 判断一个字符c是不是小写字母:
c >= 'a' && c <= 'z'
或islower(c)
- 判断一个字符c是不是大写字母:
- 大小写转换
字符c是一个字母
大写转小写:c = c - 'A' + 'a'
或tolower(c)
小写转大写:c = c - 'a' + 'A'
或toupper(c)
其中tolower(),toupper()是<cctype>中的函数
对于toupper函数,如果传入的是大写字母,会返回该大写字母本身。
对于tolower函数,如果传入的是小写字母,会返回该小写字母本身。
【题解代码】
解法1:使用toupper和tolower函数
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n, len;
char s[25];
cin >> n;
for(int i = 0; i < n; ++i)
{
cin >> s;
len = strlen(s);
s[0] = toupper(s[0]);
for(int j = 1; j < len; ++j)
s[j] = tolower(s[j]);
cout << s << endl;
}
return 0;
}
解法2:使用字符ASCII码原理
#include <bits/stdc++.h>
using namespace std;
int main()
{
string s;
int n;
cin >> n;
for(int i = 0; i < n; ++i)
{
cin >> s;
if(s[0] >= 'a' && s[0] <= 'z')//如果首字母是小写字母
s[0] = s[0] - 'a' + 'A';//变为大写字母
for(int j = 1;j < s.length(); ++j)
{
if(s[j] >= 'A' && s[j] <= 'Z')//如果某字母是大写字母
s[j] = s[j] - 'A' + 'a';//变为小写字母
}
cout << s << endl;
}
return 0;
}