删除数组中的重复元素,给定一维整型数组array,
(1)如果数组中的某个元素与排在它之后的元素重复,则对其进行删除(删除后面的),直到数组中没有重复元素为止。
例如:1,2,3,4,3,
输出:1,2,3,4
#include<stdio.h>
#define N 1000
int main()
{
int num[N],n, i, j,k=0;
scanf("%d", &n);
for (i = 0; i < n; i++)
scanf("%d", &num[i]);;
for(i=0;i<n;i++)
{
for(j=i+1;j<n;j++)
if(num[i]==num[j])
break;
if(j==n)
num[k++]=num[i];
}
for(i=0;i<k;++i)
printf("%d",num[i]);
return 0;
}
(2)删除重复后的元素(删除前面的)
例如:1,2,3,4,3,
输出:1,2,4,3
#include<stdio.h>
#define N 5
int main()
{
int i,j,k,n=N;
int num[N]={2,3,4,5,2};
for(i=0;i<n-1;i++)
{
for(j=i+1;j<n;++j)//从num[i]的下一位开始比较,直到最后一位
if(num[i]==num[j])//如果数字重复
{
for(k=i;k<n-1;++k)//从num[j]开始,所有数字前移一位
num[k]=num[k+1];//将num[j]后面元素前移一个位置
--n;//数组-1
--j;//因为有++j,所以减一下,否则num[i]前移后会漏掉一个数
}
}
for(i=0;i<n;++i)
printf("%d",num[i]);
return 0;
}
保证剩余元素的相对次序保持不变,打印删除重复元素后的数组