题目描述
一个名单里面有大型机械的很多零部件名,但是由于制作这个名单的人习惯不太好,零部件的名称的大小写很混乱。有的是大写字母开头,有些是小写字母开头,零部件名称中间的字符也是大小写混乱。
请你设计程序,将名单上零部件的名称都变为开头字母大写,后面字母全小写的形式。
输入
输入第一行只有一个正整数N ,表示名单上的零部件(1≤N≤100 )。
之后的N 行:为N 个零部件的名称。
输出
输出为N 行,为所有N 个零部件的名称,首字母为大写,后面的字母为小写。
输出的每行为一个名字,N 个名称按照字典序升序排列。
样例输入1
3
assETs
lOp
HEad
样例输出1
Assets
Head
Lop
#include <stdio.h>
#include <string.h>
void dictionary(char *a) {
int i = 0;
while (a[i]) {
if (a[0] >= 'a' && a[0] <= 'z')
a[0] -= 32;
i++;
if (a[i] >= 'A' && a[i] <= 'Z')
a[i] += 32;
}
//printf("%s\n", a);
}
void swap(char *a, char *b) {
char temp[100];
strcpy(temp, a);
strcpy(a, b);
strcpy(b, temp);
}
int main() {
int n;
int i = 0;
scanf("%d", &n);
char str[100][100];
for (i = 0; i < n ;i++) {
scanf("%s", str[i]);
//printf("%s\n", str[i]);
}
for (i = 0; i < n ;i++) {
dictionary(str[i]);
}
for (int i = 0; i < n; i++) {
for (int j = i + 1; j < n; j++) {
if (strcmp(str[i],str[j]) > 0) {
swap(str[i], str[j]);
}
}
}
for(i = 0; i < n; i++) {
printf("%s\n", str[i]);
}
return 0;
}
#include <iostream>
#include<string>
#include<algorithm>
using namespace std;
int main() {
int n;
string str[105];
cin >> n;
for (int i = 0; i < n; i++) {
cin >> str[i];
}
for (int i = 0; i < n; i++) {
if (str[i][0] >= 'a' && str[i][0] <= 'z') {
str[i][0] -= 'a' - 'A';
}
for (int j = 1; j < str[i].size(); j++) {
if (str[i][j] >= 'A' && str[i][j] <= 'Z') {
str[i][j] += 'a' - 'A';
}
}
}
sort(str, str + n);
for (int i = 0; i < n; i++) {
cout << str[i] << endl;
}
return 0;
}