❶ (c语言)输入一串字符,按从小到大顺序排列并删除重复项。
#include<stdio.h>
#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;
}
❷ #c语言编程#实现将字符串中所有重复的字符剔除,将剔除之后的输出 如sajsk输出ajk
#include <stdio.h>
#include <string.h>
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;
}
❸ C语言去掉重复字符再排序
char a[30] = "qweasdzxcvbnhbgfvredcxswqazx";
for (int i = 0; i < 30; i++) {
printf("%c",a[i]);
for (int j = 0; j < i; j++) {
if (a[i] == a[j]) {
a[i] = '0';
}
}
}printf("\n");
for (int i = 0; i< 30; i++) {
if (a[i] != '0') {
printf("%c",a[i]);
}
}
用两个for循环,将字符串的每一个字符和前一个进行比较,如果有一个相同,将他等于字符串内不同的一个字符(很重要),然后另作一个for循环,将不含有这个字符的字符串输出
qweasdzxcvbnhbgfvredcxswqazx
qweasdzxcvbnhgfr
还给你一个方法,先排序,然后将,a[i]==a[i+1]的时候,将a[i]='0',也可以做出来,但是位置变化了
❹ C语言中删除字符串中的重复字符,然后输出新的字符串
#include<stdio.h>
#include<string.h>
intmain()
{
charc,str[80];
inti=0,j,k,len;
printf("input:");
gets(str);
len=strlen(str);
c=str[i];
while(c!='