C语言で重複する文字列をどのようにフィルタリングすればよいか

二重ループで走査・比較を行い、重複した文字列が見つかればフィルタリングします。

以下のコード例をご参照ください。

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

void filterDuplicateStrings(char strings[][100], int n) {
    int i, j;
    for (i = 0; i < n; i++) {
        if (strings[i][0] == '\0') { // 已经被过滤掉的字符串
            continue;
        }
        for (j = i + 1; j < n; j++) {
            if (strcmp(strings[i], strings[j]) == 0) {
                strings[j][0] = '\0'; // 将重复的字符串置为空字符串
            }
        }
    }
}

int main() {
    char strings[][100] = {
        "apple",
        "banana",
        "orange",
        "apple",
        "kiwi",
        "banana"
    };
    int n = sizeof(strings) / sizeof(strings[0]);

    filterDuplicateStrings(strings, n);

    printf("After filtering duplicate strings:\n");
    for (int i = 0; i < n; i++) {
        if (strings[i][0] != '\0') {
            printf("%s\n", strings[i]);
        }
    }

    return 0;
}

ネイティブな日本語に言い換えると次のようになります。

After filtering duplicate strings:
apple
banana
orange
kiwi

この例では 2 次元文字配列を使用して文字列を保存していますが、状況に応じて変更できます。

bannerAds