#include
#include"string.h"
int main(void)
{
char str1[500]={0},str2[256]={0};//定义二个数组,并赋初值为0
int i;
gets(str1);//读取一个字符串
for(i=0;str1[i];i++)
{
str2[str1[i]]=1;//str1中每个字符的assic码作为str2的下标值,并把对应位置填充为1,同一个字符的assci值相同,所以这样就去掉了重复字符
}
for(i=0;i!=256;i++)
if(str2[i]==1)//判断数组中被str1填充的位置,填充的是非0值,没填充的是0值
printf("%c",i);//输出str2的下标值,对应str1中的字符值
putchar('\n');
return 0;
}
#include
#include
void sort(char s[]) { // 选择排序
int i,j,k,t,len = strlen(s);
for(i = 0; i < len - 1; ++i) {
k = i;
for(j = i + 1; j < len; ++j) {
if(s[k] < s[j]) k =j;
}
if(i != k) {
t = s[i];
s[i] = s[k];
s[k] = t;
}
}
}
// 将不重复的字符复制到t[],返回删除的字符个数
int change(char s[], char t[]) {
int i = 1,j = 0,cnt = 0;
sort(s);
t[0] = s[0];
while(s[i]) {
if(s[i] == s[i - 1]) ++cnt;
else t[++j] = s[i];
++i;
}
t[j] = '\0';
return cnt;
}
int main() {
char s[] = "aseqkwh wkqhasweewwqbkh112504ffvsdr";
char t[60];
printf("原串:%s\n",s);
printf("共删除%d个字符。\n",change(s,t));
printf("最后得到的字符串为:%s\n",t);
return 0;
}
冒泡排序就可以