题干:
删除数组中的重复元素 给定一维整型数组array(数组大小不超过100),如果数组中的某个元素与排在它之后的元素重复,则对其进行删除,直到数组中没有重复元素为止。保证剩余元素的相对次序保持不变,打印删除重复元素后的数组。首先输入数组大小,输入格式为"%d",然后依次输入数组中的元素,输入格式为“%d”,依次输出删除重复元素后的数组中的每个元素,输出格式为“%d ” 输入样例: 14 1 2 3 4 5 6 1 7 5 0 4 9 8 1 输出样例: 2 3 6 7 5 0 4 9 8 1
个人解答(保留前方的删除后续的重复数):
#include<stdio.h>
#define m 100
int main()
{
int n,i,j,g;
scanf("%d", &n);
int len=0;
int arr[m];
for (i = 0; i < n; i++)
{
scanf("%d", &arr[i]);
}
for (i = 0; i < n; i++)
{
for (j = i + 1; j < n+1; j++)
{
if (arr[i] == arr[j])
{
for (g = j; g < n; g++)
{
arr[g] = arr[g + 1];
}
}
}
}
for (i = 0; arr[i] >=0; i++)
{
len ++;
}
for (i = 0; i < len; i++)
{
printf("%d", arr[i]);
}
return 0;
}