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?
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?
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]);
}
jemand mir sagen, warum ich downvoted werde? – raymai97
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. –
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;
}
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. –
entfernen Sie die Elemente und realloc den verwendeten Speicher – cleoc
So. Dieses Array wurde dynamisch mit malloc() zugewiesen und es ist eine Längenvariable zugeordnet? –