//数组最好有一个初始值
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] {
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:你这根本就不能叫算法,毫无效率可言)
你在进行删除时每一次只删除一个相同的字符,应该在面再加一个循环,保证输入11111111时输出一个1。
#include
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] {
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;
}
没错啊,我就是运行你的代码的。。。。。
你这个输出是对的呀,没什么问题啊?