单词排序
【问题描述】
编写一个程序,从一个文件中读入单词(即:以空格分隔的字符串),并对单词进行排序,删除重复出现的单词,然后将结果输出到另一个文件中。
【输入形式】
从一个文件sort.in中读入单词。
【输出形式】
对单词进行排序,删除重复出现的单词,然后将结果输出到文件sort.out中。
【输入样例】
假如sort.in文件内容如下:
rrr sss aaa bbb ccc ddf aaa dd
【输出样例】
sort.out文件内容为:
aaa bbb ccc dd ddf rrr sss
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 比较函数,用于 qsort 排序
int compare(const void *a, const void *b) {
return strcmp((const char *)a, (const char *)b);
}
int main() {
FILE *fp_in, *fp_out;
char words[100][50]; // 假设最多 100 个单词,每个单词最长 50 个字符
int num_words = 0;
int i;
// 打开输入文件
fp_in = fopen("sort.in", "r");
if (fp_in == NULL) {
printf("无法打开输入文件\n");
return 1;
}
// 读取单词
while (fscanf(fp_in, "%s", words[nu