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 次元文字配列を使用して文字列を保存していますが、状況に応じて変更できます。