#include<stdio.h> #include <string.h> #include <stdlib.h> int main() { FILE *f, *g; char temp[20]; char w[100][20]; int i, j = 0, count = 0; f = fopen("in.txt", "r"); g = fopen("words.txt", "w"); while (!feof(f)) //读入字符串(以单词的形式) fscanf(f,"%s", w[count++]); rewind(f); for(i=0;i<count;i++) { for(j=0;j<strlen(w[i]);j++) { if((w[i][j]<= 'z'&&w[i][j]>= 'a') || (w[i][j]<= 'Z'&&w[i][j]>= 'A')||w[i][j]==' ') { if(w[i][j]>='A'&&w[i][j]<='Z') w[i][j]+=32; } else w[i][j]='\0'; } } for (i = 0; i < count; i++) { if(strcmp(w[i], "which") == 0){ strcpy(w[count++], "purpose"); continue; }else if(strcmp(w[i], "york") == 0){ strcpy(w[count++], "th"); continue; } } count++; for(i=0;i<count;i++) { for(j=i;j<count-1;j++) { if(strcmp(w[i],w[j])>0) { strcpy(temp,w[i]); strcpy(w[i],w[j]); strcpy(w[j],temp); } } } fprintf(g,"%s\n",w[0]); for(i=1;i<count-1;i++) { if(strcmp(w[i],w[i-1])!=0) fprintf(g,"%s\n",w[i]); } fclose(f); fclose(g); return 0; }
时间: 2024-01-04 18:04:57 浏览: 66
#include<stdio.h>
该代码实现了读入一个文件中的单词,并将单词按字典序排序后输出到另外一个文件中。其中还包括了一些特殊操作,如将"which"替换为"purpose",将"york"替换为"th"等。
代码思路:
1. 打开输入文件和输出文件。
2. 读入输入文件中的单词,存储到一个二维字符数组中。
3. 对每个单词进行处理,将其中的大写字母转换为小写字母,并将非字母字符替换为'\0'。
4. 进行特殊操作,将"which"替换为"purpose",将"york"替换为"th"等。
5. 对存储单词的数组进行排序,按照字典序从小到大排序。
6. 将排序后的单词依次输出到输出文件中,去除重复的单词。
需要注意的是,该代码中存在一些问题,例如:
1. 在读取单词时,使用了feof函数进行判断,这样可能会读取到最后一个单词两次。
2. 在进行特殊操作时,修改了count的值,导致后面的单词无法被处理。
3. 在进行去重操作时,没有考虑到最后一个单词可能会和前面的单词重复。
因此,建议在使用该代码时进行修改和改进。
阅读全文