题目
本题要求编写程序,将给定字符串去掉重复的字符后,按照字符ASCII码顺序从小到大排序后输出。
输入格式:
输入是一个以回车结束的非空字符串(少于80个字符)。
输出格式:
输出去重排序后的结果字符串。
输入样例:
ad2f3adjfeainzzzv
输出样例:
23adefijnvz
AC代码
- 去除重复字符太麻烦了,还要排序
- 直接开个长度为150的整型数组,将字符串当作单个字符来处理,将每个字符的asc码值当做数组下标,标记对应数组元素,输出时直接遍历数组,输出被标记的元素,将该元素的下标当asc码值以%c字符形式输出。
#include<stdio.h>
int main(){
int count[150]={0}; //初始化全为0
char ch;
while((ch=getchar())!='\n'){
count[ch]++; //可以记录每个字符出现次数,当然,没必要,可以改成其它标记方式
}
for(int i=32;i<127;i++){ //本来是从0输出到150的,查表发现可见字符码值范围为(32,126)
if(count[i]!=0)printf("%c",i);
}
return 0;
}