编写一个程序,从键盘接收一个字符串,然后按照字符顺序从小到大进行排序,并删除重复的字符

#include <stdio.h>
int main()
{
char a[100];
int i=0,j,t,b;
printf("");
while((a[i]=getchar())!='\n')
i++;
t=i-1;
for(i=0;i<=t;i++)
{
for (j=i+1;j<=t;j++)
{
if(a[j]<a[i])
{
b=a[j];
a[j]=a[i];
a[i]=b;
}
}
}
j=t;
for(i=0;i<=j;i++)
{
if(a[i]==a[i+1])
{
for(j=i+1;j<=t;j++)
a[j]=a[j+1];
}
}
for(i=0;i<=j;i++)
{
printf("%c",a[i]);
}
return 0;
}
求指点错误

//数组最好有一个初始值
char a[100] = {0};
int i=0,j,t,b;
printf("");
//得到输入的字符串和个数
while((a[i]=getchar())!='\n')
i++;
//得到数组终止角标
t=i-1;
// 使用冒泡法进行排序
for(i=0;i<=t;i++)
{
for (j=i+1;j<=t;j++)
{
if(a[j]<a[i])
{
b=a[j];
a[j]=a[i];
a[i]=b;
}
}
}
//去除重复的,这里有错误
//j=t; 角标混用,造成了混乱
for(i=0;i<=t;i++)
{
//如果a[i]和a[i+1]相同
if(a[i]==a[i+1])
{
//试图将后面的数组向前整体移动一个,
for(j=i+1;j<=t;j++)
{
a[j]=a[j+1];
}
//整体移动后却忘了i也应该减1
i--;
//整体移动后相当于数组整体变小了1个
t--;

}
}
//打印
for(i=0;i<=t;i++)
{
printf("%c",a[i]);
}

system("pause");
return 0;

//只是帮你 改了下能达到目的,算法上没动(PS:你这根本就不能叫算法,毫无效率可言)
温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-11-08
你在进行删除时每一次只删除一个相同的字符,应该在面再加一个循环,保证输入11111111时输出一个1。

#include <stdio.h>
int main()
{
char a[100];
int i=0,j,t,b;
printf("");
while((a[i]=getchar())!='\n')
i++;
t=i-1;
for(i=0;i<=t;i++)
{
for (j=i+1;j<=t;j++)
{
if(a[j]<a[i])
{
b=a[j];
a[j]=a[i];
a[i]=b;
}
}
}
j=t;
for(int k=0;k<=j;k++) //在你原来的基础上加一个循环
{
for(i=0;i<=j;i++)
{
if(a[i]==a[i+1])
{
for(j=i+1;j<=t;j++)
a[j]=a[j+1];
}
}
}
for(i=0;i<=j;i++)
{
printf("%c",a[i]);
}
return 0;
}
第2个回答  2013-11-08

没错啊,我就是运行你的代码的。。。。。

追问

他会打出好多换行,而且你要是把一个字符重复输入很多次就不行了

第3个回答  2013-11-08
你这个输出是对的呀,没什么问题啊?追问

他会打出好多换行,而且你要是把一个字符重复输入很多次就不行了