本题要求编写程序,顺序输出给定字符串中所出现过的大写英文字母,每个字母只输出一遍;若无大写英文字母则输出“Not Found”。
输入格式:
输入为一个以回车结束的字符串(少于80个字符)。
输出格式:
按照输入的顺序在一行中输出所出现过的大写英文字母,每个字母只输出一遍。若无大写英文字母则输出“Not Found”。
输入样例1:
FONTNAME and FILENAME
结尾无空行
输出样例1:
FONTAMEIL
结尾无空行
输入样例2:
fontname and filrname
输出样例2:
Not Found
#include <stdio.h>
#define N 80
main() {
char a[N], output[N], ch; //创建一个字符数组a读入, 字符数组output储存输出的大写字母
int i, flag = 1, num = 0; //flag 判断是否输出“Not Found”, num作为output字符数组的下标
gets(a); //读入数组a
for(i=0; a[i] != '\0'; i++) { //gets得到的字符数组最后一定以/0结尾, 遍历数组a判断数组Output
int breakFlag = 0;
// a[i] = ch;
// ch = getchar();
if(a[i] >= 'A' && a[i] <= 'Z') { //直接判断若为大写字母则储存在输出字符串 output里
flag = 0;
int j;
if(!num) {
output[num++] = a[i];
} else {
for(j=0; j<num; j++) {
if(a[i] == output[j]) {
breakFlag = 1; //如果字母已经出现过, 那么回到外层循环
break;
}
}
if(breakFlag) continue;
output[num++] = a[i]; //用后++来让下标自增
}
}
}
if(flag) {
printf("Not Found");
} else {
for(i=0; i<num; i++) {
printf("%c", output[i]);
}
}
return 0;
}