2016-04-24 10 views
0

sagen, dass ich ein Array haben:C: Wie lösche ich benachbarte Duplikate im 1D-Array?

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

und ich möchte alle benachbarten Duplikate löschen, so dass es

int {2, 6, 2, 5} 

wird Wie kann ich das tun?

+0

Bitte erläutern Sie, was Sie mit 'Löschen' whith ein Integer-Array. Es gibt keine "ungültigen" Werte, um irgendwelche Leerzeichen zu füllen. –

+0

entfernen Sie die Elemente und realloc den verwendeten Speicher – cleoc

+0

So. Dieses Array wurde dynamisch mit malloc() zugewiesen und es ist eine Längenvariable zugeordnet? –

Antwort

0

Nicht sicher, was Sie versucht haben. Meine Idee wäre so.

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

jemand mir sagen, warum ich downvoted werde? – raymai97

+0

Ich bin nicht downvote es, aber auf den ersten Blick kann ich Ihnen sagen, dass Ihre Antwort annehmen, die ersten aufeinander folgenden Elemente ist nicht 0, also {0, 0, 0, 6, 6, 2, 2, 5, 5, 5} verdient 6 2 5 ist falsch. –

-1

wie folgt aus:

#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; 
} 
Verwandte Themen