概述
删除一个数组或字符串中的重复元素并对其进行排序的问题大概大家都遇到过。
之前我的思路:
1.先将数组里所有的元素排序。
2.用将数组元素向前移覆盖掉重复元素的方法删除重复元素。
#include<stdio.h>
#include<string.h>
int num;
void rank(char *str,int num)
{
int i,j;
char temp;
for(i=0;i<num-1;i++)
for(j=i+1;j<num;j++)
if(str[i]>str[j])
{
temp=str[i];
str[i]=str[j];
str[j]=temp;
}
}
void de(char str[],int *num)
{
int i,j,k;
for(k=0;k<=*num;k++)
{
for(i=0;i<*num-1;i++)
if(str[i]==str[i+1])
{
for(j=i;j<*num-1;j++)
str[j]=str[j+1];
(*num)--;
}
}
}
int main()
{
char str[100];
gets(str);
int num,i,j,k;
num=strlen(str);
for(i=0;i<num;i++)
{
if(str[i]==' ')
{
for(j=i;j<num-1;j++)
str[j]=str[j+1];
num--;
}
}
rank(str,num);
de(str,&num);
for(i=0;i<num;i++)
printf("%c",str[i]);
return 0;
}
天哪,这种方法真的要写太多了吧!
后来发现有另一种解法:制表法。(有可能在其它地方不叫这种方法)。
这种方法跟上面一种方法相比的优缺点是:
优点:代码看起来简洁了许多。
缺点:与上面的方法相比占用了更多的内存空间。
代码如下:
#include<stdio.h>
int main()
{
char a[20],b[256]={0};//此处的b数组必须要进行初始化。一个数组申明后,如果没有赋值,那么只是分配了内存空间,没有具体的值,也可以说是空,其组成是“ ”也就是NULL,无法在实际中使用。
int i;
gets(a);
for(i=0;a[i];i++)
b[a[i]]=1;//标记b数组的数组下标
for(i=0;i<256;i++)
if(b[i]==1)
printf("%c",i); //输出被标记的数组下标
putchar('