C:如何删除1D数组中的相邻重复项

说我有一个数组:

说我有一个数组:

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

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

int {2, 6, 2, 5}

我该怎么做?

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]);
}
-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;
}

本站系公益性非盈利分享网址,本文来自用户投稿,不代表码文网立场,如若转载,请注明出处

(911)
GoogleChrome版本83.0.4103.97无法在Windows10上访问/打开相机
上一篇
如何将背景转换为透明 (lunapic transparent signature)
下一篇

相关推荐

发表评论

登录 后才能评论

评论列表(88条)