2016-04-24 66 views
0

说我有一个数组:C:如何删除一维数组中的相邻副本?

int {2, 2, 2, 6, 6, 2, 2, 5, 5, 5} 

,我想删除所有相邻重复,使之成为

int {2, 6, 2, 5} 

我怎样才能做到这一点?

+0

请解释一下你的 '删除' 蒙山一个整数数组的意思。没有“无效”值填写任何空格。 –

+0

删除元素并重新分配使用的内存 – cleoc

+0

所以。这个数组,它是用malloc()动态分配的,它有一个与它相关的长度变量? –

回答

0

不知道你试过了什么。我的想法是这样的。

int i, num[] = {2, 2, 2, 6, 6, 2, 2, 5, 5, 5}; 

// Prepare new array for the result (result never larger than num[]) 
int *newNum = malloc(sizeof(num)); 
int used = 0, last = 0; 

// Get number of elements in num[], which is 10 in this example 
size_t n = sizeof(num)/sizeof(int); 

for (i = 0; i < n; i++) 
{ 
    if (num[i] != last) 
    { 
     newNum[used++] = num[i]; 
    } 
    last = num[i]; 
} 

printf("new array: \n"); 
for (i = 0; i < used; i++) 
{ 
    printf("%i ", newNum[i]); 
} 
+0

有人告诉我为什么我会陷入低谷? – raymai97

+0

我并不低调,但乍看之下,我可以告诉你,你的答案假设第一个连续的元素不是0,所以{0,0,0,6,6,2,2,5,5, 5}赚取6 2 5是错误的。 –

-1

这样的:

#include <stdio.h> 
#include <stdlib.h> 
#include <string.h> 

int main(void){ 
    int size = 10; 
    int *array = memcpy(malloc(size * sizeof(*array)), (int[]){2, 2, 2, 6, 6, 2, 2, 5, 5, 5}, size * sizeof(*array)); 
    int i, new_size; 

    for(i = new_size = 1; i < size; ++i){ 
     if(array[new_size-1] != array[i]) 
      array[new_size++] = array[i]; 
    } 
    if(size > new_size){ 
     size = new_size; 
     array = realloc(array, size * sizeof(*array)); 
    } 
    for(i = 0; i < size; ++i) 
     printf("%d ", array[i]);//2 6 2 5 

    free(array); 
    return 0; 
}