编写函数把整数数组中值相同的元素删除的只剩一个,并把剩余元素全部移动到前面
//删除整数数组中值相同的元素 只留一个
//a[i]=a[i-1]就往前移动
//注意最后剩下的数组有效长度(每次删除一个元素 数组长度-1
#include<stdio.h>
#define n 5
int main(){
int a[n],i,j,k;
for(i=0;i<n;i++){
scanf("%d",&a[i]);
}
i=1;
k=0;
while(i<n-k){//每次去掉一个重复元素 数组有效长度-1
if(a[i]==a[i-1]){
for(j=i;j<n;j++){
a[j-1]=a[j];//后面的元素覆盖前面的元素 后面的不变
}
k++;//删除的元素个数
}
else{
i++;
}
}
for(i=0;i<n-k;i++){
printf("%d ",a[i]);
}
return 0;
}