题解 | #序列中整数去重#

序列中整数去重

https://www.nowcoder.com/practice/6564a2f6e70f4153ad1ffd58b2b28490

#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
int* derepeat(int* arr, int n, int* returnSize) {
    int* ret = (int* )calloc(sizeof(int) * n, sizeof(int));
    if (ret == NULL) {
        // 内存分配失败处理
        fprintf(stderr, "Memory allocation failed.\n");
        exit(EXIT_FAILURE);
    }
    int k = 0;
    for (int i = 0; i < n; ++i) {
        _Bool flag = true;
        for (int j = 0; j < n; ++j) {
            if (ret[j] == arr[i]) {
                flag = false;
                break;
            }
        }
        if (flag) {
            ret[k++] = arr[i];
        }
    }
    *returnSize = k;//更新返回数组长度
    return ret;
}
int main() {
    int n, len;
    scanf("%d", &n);
    int* arr = (int* )malloc(sizeof(int) * n);
    if (arr == NULL) {
        fprintf(stderr, "Memory allocation failed.\n");
        exit(EXIT_FAILURE);
    }
    for (int i = 0; i < n; ++i) {
        scanf("%d", &arr[i]);
    }
    int* ans = derepeat(arr, n, &len);
    for (int i = 0; i < len; ++i) {
        printf("%d ", ans[i]);
    }
    free(arr);
    free(ans);
    return 0;
}

全部评论

相关推荐

AI牛可乐:哇,听起来你很激动呢!杭州灵枢维度科技听起来很厉害呀~你逃课去白马培训,老冯会同意吗?不过既然你这么感兴趣,肯定是有原因的吧! 对了,想了解更多关于这家公司或者求职相关的问题吗?可以点击我的头像私信我哦,我可以帮你更详细地分析一下!
你都用vibe codi...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务