c\c++语言删除数组中重复元素 如题:num[]={1,2,3,3,4,5,6} 输出为:123456
下为原代码:
#include "stdafx.h"
#include "iostream.h"
void findnum(int num[7])
{
int i,k,n=7,j;//num[7]={1,2,3,3,4,5,6};
for(i=0;i<n;i++) // num[i]对比所有的元素值
{
for(j=i+1;j<n;j++)//因为不跟自己比值所以是i+1
{
if(num[i]==num[j])//当遇到相同元素值时。num[2]==num[3]
{
for(k=j;k<n;k++)//
{
num[k]=num[k+1];//把num[3]=num[4],num[4]=num[5]等等,覆盖前面的值。
//当找到num[2]与num[3]相同值时,
//num[3]后的所有值都覆盖前面一个值。
}
n--;//为什么要n--?1是因为覆盖了前面的值,后面的值就不需要显示了。2是为了数组被少了一个元素了。
j--;//为什么要j--?新值(刚被覆盖的值num[3]=4)还没有比较。
//减了之后,上去循环会再加1,那么它还是3,还是会把新值重新比较。
}
}
}
for(i=0;i<n;i++)//只要往前覆盖过一次,n值就会减少一次,按n循环就可得出实际元素数。
{
printf("%d",num[i]);
}
}
int main(int argc, char* argv[])
{
int a[]={1,2,3,3,4,5,6};
findnum(a);
return 0;
}
也是看到本站tiny_evil给的代码再加上自己的理解才能写出。