当前位置:首页 » 编程语言 » c语言删除重复字符并排序后输出
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言删除重复字符并排序后输出

发布时间: 2022-07-21 04:29:35

❶ (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!='')
{
for(j=i+1;str[j]!='';j++)
{
if(str[j]==c)
{
for(k=j;str[k]!='';k++)
str[k]=str[k+1];
len--;
}
}
c=str[i++];
}
puts(str);
getchar();
}

改动后可以运行了,你的错误:
1.包含的第二个头文件少写个h
2.在发现重复字符后需要删除时,if语句里for循环使用了j和外面大循环的j重复,会造成不可预料的错误
3.else后面的赋值不正确,应该等第一个for循环结束后,而不是if判断后

❺ C语言编程:从键盘输入一个有空格的字符串,删除所有重复字符,按字符升序输出在屏幕上。怎么做

代码文本:

#include "stdio.h"

int main(int argc,char *argv[]){

char a[101],*p,*px,t;

printf("Input a string... ");

for(p=a,t=0;t<100;t++)//输入字符串

if((*(p+t)=getchar())==' ')

break;

*(p+t)='';

for(p=a;*p;p++)//排序

for(px=p+1;*px;px++)

if(*p>*px){

t=*p;

*p=*px;

*px=t;

}

for(p=a;*p;p++){//删除重复字符

for(t=1;*p==*(p+t);t++);

if(t>1){

for(px=p;*px=*(px+t);px++);

p--;

}

}

printf(*a ? " %s " : " (null) ",a);//输出

return 0;

}

供参考。

❻ 求C语言代码,删除字符串中重复字符 如输入"aabbcc",要求输出"abc"

字符也可以使用整数来表示,其实整数0-255用%c来输出就是字符。
#include <stdio.h>
int main() {
char s[256]; /*初始化了一个数组来存放输入的串*/
int i = 0, tmp[256] = {0}; /*tmp是一个256个整型数组,初始化成全0*/
printf("Enter the string :\n");
gets(s); /*将输入的串存到s中*/

/*分析每个输入的字符,如果字符是'a' 则a=97,那么 tmp[97]将置成1 ,如果下一个字符串还是
'a',那么同样tmp[97]置成1,如果下一个字符是'b',那么tmp[98]将置成1......*/
while(s[i] != '\0')
tmp[s[i++]] = 1;

puts("\nAfter sort and delete operation:");
/*顺序输出255个字符中s串中包含的字符*/
for(i = 0; i < 256;i++)
if(tmp[i])
printf("%c", i);
return 0;
}

那么等于是说全部ascii字符集是256个,如果有哪个字符那么就把它标记上,然后再从0开始顺序输出就可以了。

❼ c语言删除字符串中重复的内容并排序

//删除字符串中重复的字符并排序
#defineN6
#include<stdio.h>
main()
{ //定义变量

inti,j,k,n=0;
charch[100],t;

//输入

for(i=0;i<N-1;i++)
scanf("%c",&ch[i]);

//删除重复字符

for(i=0;i<N-1-n;i++)
{
for(j=0;j<i;j++)
{
if(ch[i]==ch[j])
{
for(k=j;k<N-1-n;k++)
ch[k]=ch[k+1];
j--;
n++;
}
}
}

//输出(无重复字符)

k=N-n-1;
for(i=0;i<k;i++)
printf("%c",ch[i]);
printf(" ");

//排序(冒泡法)

for(i=0;i<k-1;i++)
{
for(j=0;j<k-1-i;j++)
{
if(ch[j]>ch[j+1])
{
t=ch[j];
ch[j]=ch[j+1];
ch[j+1]=t;
}
}
}

//输出(无重复字符并排序)

for(i=0;i<k;i++)
printf("%c",ch[i]);
printf(" ");

//结束

return0;
}

❽ c语言排序后删除数组中重复的数字再排序输出

#include<stdio.h>

#include<string.h>

#defineSIZE81

voiddelete_repeat(char*str);

voidbubble_sort(char*str);

intmain()

{

charstr[SIZE];

gets(str);

delete_repeat(str);

bubble_sort(str);

puts(str);

return0;

}

//删除重复字符

voiddelete_repeat(char*str)

{

/**判断数组内第i个字符是否与前i-1个字符存在重复:

若重复,删除该字符,i之后的字符下标均减1,后重新判断新的第i个字符

若不重复,不做处理,继续遍历下一个

*/

for(inti=1;str[i]!='';i++){

for(intj=0;j<i;j++)

{

if(str[i]==str[j])

{

for(intk=i;k<strlen(str)-1;k++)

{

str[k]=str[k+1];

}

str[strlen(str)-1]='';

i--;

}

}

}

}

//冒泡排序

voidbubble_sort(char*str)

{

intswap;

chartemp;

intk=strlen(str);

do{

swap=0;

for(inti=0;i<k-1;i++){

if(str[i]>str[i+1])

{

swap=1;

temp=str[i];

str[i]=str[i+1];

str[i+1]=temp;

}

}

k--;

}while(k>0&&swap);

}

(8)c语言删除重复字符并排序后输出扩展阅读

删除排序数组中的重复项注意事项

不要使用额外的数组空间,必须在原地修改输入数组并在使用O(1)额外空间的条件下完成,意味着不能通过新建数组存放的方式解决。

可以考虑增加一个游标的方式(命名为:index),遍历整个数组,当遇到前一个和后一个不相等的时候就给游标自增,这样的话对于相同的元素可以直接跳过不统计,最后返回”游标的大小+1“(也即不重复的元素的个数)。