服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C语言实现单词小助手改进版

C语言实现单词小助手改进版

2021-08-04 12:04Tc-Raziel C/C++

这篇文章主要为大家详细介绍了C语言实现单词小助手的改进版,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文为大家分享了C语言单词小助手的具体实现代码,供大家参考,具体内容如下

一.题目分析

单词小助手,要求完成以下任务:

1.改写程序为良好程序风格(文档注释,函数注释,语句注释)。

2.将单词测试中的功能完善,可针对做错的单词重复记忆。

3.查询单词的功能添加英文词查询,中文查询的功能完善(考虑如何显示同样中文意义,不同的英文单词)

提高要求:

可将程序中的不足(如数据验证,排名功能)等根据自己的能力与理解完成。

二.算法构造(新增函数)

流程图

(1)总流程图

C语言实现单词小助手改进版

(2)search()函数流程图

C语言实现单词小助手改进版

(3)repeat()函数流程图

C语言实现单词小助手改进版

三.程序实现

  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <stdlib.h>
  4. #define MAX_CHAR 20 // 最大字符
  5. #define MAX_NUM 200 // 单词的最大个数
  6. struct word
  7. //单词的结构体
  8. {
  9. char en[MAX_CHAR]; // 英文形式
  10. char ch[MAX_CHAR]; //中文形式
  11. }
  12. s[MAX_NUM]; //单词数组
  13. int num; //单词个数
  14. int select=1;//select 为是否退出系统的标记
  15. int d=0,c=0;//c为答错的次数,d为答对的次数
  16. //帮助
  17. void help()
  18. {
  19. printf("\n本系统主要实现英语单词学习的功能。用户可对词典文件中的单词进行预览,增删改查。");
  20. printf("\n同时还可进行中英、英中测试。本系统还提供了测试成绩的显示功能。");
  21. }
  22.  
  23. //从文件中读取单词的信息
  24. void readfile()
  25. {
  26. FILE *fp;
  27. int i=0;
  28. fp=fopen("E:\\data.txt","r");
  29. if(!fp)
  30. {
  31. printf("\n打开文件data.txt失败!");
  32.  
  33. }
  34. while(fscanf(fp,"%s %s ",s[i].en,s[i].ch)==2)
  35. {
  36. i++;
  37. }
  38. num=i;
  39. if(i==0)
  40. printf("\n文件为空,请选择词典维护增加词条!");
  41. else
  42. printf("\n");
  43. fclose(fp);//关闭文件
  44.  
  45. }
  46. //向文件中写入单词
  47. void writefile()
  48. {
  49. FILE *fp;
  50. int i=0;
  51. fp=fopen("E:\\data.txt","w");
  52. if(!fp)
  53. {
  54. printf("\n打开文件data.txt失败!");
  55.  
  56. }
  57. for(i=0;i<num;i++)
  58. {
  59. fprintf(fp,"\n%s %s ",s[i].en,s[i].ch);
  60. }
  61. printf("\n");
  62. fclose(fp);
  63. }
  64. void sort()/*按字典排序*/
  65. {
  66. int i,j;
  67. char temp[MAX_CHAR];
  68. for(i=0;i<num-1;i++)
  69. {
  70. for(j=num-1;j>i;j--)
  71. if(strcmp(s[j-1].en,s[j].en)>0)
  72. {
  73. strcpy(temp,s[j-1].en);
  74. strcpy(s[j-1].en,s[j].en);
  75. strcpy(s[j].en,temp);
  76. strcpy(temp,s[j-1].ch);
  77. strcpy(s[j-1].ch,s[j].ch);
  78. strcpy(s[j].ch,temp);
  79.  
  80. }
  81. }
  82. }
  83. //定义记忆文件函数,用来记忆背诵错误的单词,将背诵过程中错误的单词写入Repeat文件
  84. void readRepeatfile()
  85. {
  86. FILE *fp;
  87. int i=0;
  88. fp=fopen("E:\\Repeat.txt","r");//增强记忆文件
  89. if(!fp)
  90. {
  91. printf("\n打开文件失败");
  92. }
  93. while(fscanf(fp,"%s %s",s[i].en,s[i].ch)==2)
  94. {
  95. i++;
  96. }
  97. num=i;
  98. if(i==0)//没有错题
  99. printf("\n没有错题");
  100. else
  101. printf("\n");
  102. fclose(fp);
  103. }
  104. //添加单词信息
  105. void add()
  106. {
  107. int i=num,j,flag=1;
  108. int a=0,k=0;
  109. printf("你想添加几个单词:");
  110. scanf("%d",&a);
  111. while(flag)
  112. {
  113. for(k=0;k<a;k++)
  114. {
  115. flag=0;
  116. printf("\n请输入第%d个单词的英文形式:",k+1);
  117. scanf("%s",s[i].en);
  118. for(j=0;j<i;j++)
  119. if(strcmp(s[i].en,s[j].en)==0)
  120. {
  121. printf("已有该单词,请检查后重新录入!\n");
  122. flag=1;
  123. break; /*如有重复立即退出该层循环,提高判断速度*/
  124. }
  125. printf("请输入第%d个单词的中文形式:",k+1);
  126. scanf("%s",s[i].ch);
  127. num++;
  128. printf("您输入的信息为: 英文: %s 中文: %s ",s[i].en,s[i].ch);
  129. printf("\n");
  130. sort();
  131. }
  132. }
  133. }
  134. //删除单词信息
  135. void del()
  136. {
  137. int i=0,j=0;
  138. char en[MAX_CHAR]; //英文形式
  139. printf("\n请输入你要删除的单词英文形式:");
  140. scanf("%s",en);
  141. for(i=0;i<num;i++)//先找到该英文形式对应的序号
  142. if(strcmp(s[i].en,en)==0)
  143. {
  144. for(j=i;j<num-1;j++)
  145. s[j]=s[j+1];
  146. num--; //数量减少 1
  147. return;
  148. }
  149. printf("\n没有这个单词!");
  150.  
  151. }
  152. //修改单词信息
  153. void modify()
  154. {
  155. int i=0,choose=0,flag=1;//chooses代表选项标识,flag代表是否找到单词
  156. char en[MAX_CHAR]; //英文形式
  157. while(flag||choose)
  158. {
  159. printf("\n请输入你要修改的单词英文形式:");
  160. scanf("%s",en);
  161. for(i=0;i<num;i++)//先找到该英文形式对应的序号
  162. if(strcmp(s[i].en,en)==0)
  163. {
  164. printf("\n请输入单词正确的英文形式:");
  165. scanf("%s",s[i].en);
  166.  
  167. printf("\n请输入此单词正确的的中文形式:");
  168. scanf("%s",s[i].ch);
  169.  
  170. printf("\n继续修改请选1,返回上一级请选0:");
  171. scanf("%d",&choose);
  172. if(choose==0) return;
  173. }
  174. flag=0;
  175.  
  176. }
  177. if(!flag)
  178. printf("\n没有这个单词!");
  179. }
  180. //单词预览
  181. void show()
  182. {
  183. int i=0;
  184. printf("\n单词: 英文 中文 ");
  185. for(i=0;i<num;i++)
  186. printf("\n %-12s%-12s",s[i].en,s[i].ch);
  187.  
  188. }
  189. //查询单词
  190. void search()
  191. {
  192. int i = 0, choose = 0, flag = 1;//flag标记
  193. int index = -1; //检索到该单词的中文或者英文的下标
  194. int option = 0;
  195. char ch[MAX_CHAR]; //中文形式
  196. char en[MAX_CHAR]; //英文形式
  197. while(1)
  198. {
  199. printf("请输入1.以中文查询单词2.以英文查询单词0.退出");
  200. scanf("%d", &option);//可选中英文查询
  201. switch(option)
  202. {
  203. case 1:
  204. while(1)
  205. {
  206. printf("\n请输入你要查询的单词中文形式:");
  207. scanf("%s", ch);
  208. for(i=0; i<num; i++)//遍历找到所有该中文对应的单词
  209. if(strcmp(s[i].ch, ch) == 0 && index == -1)//输出该单词的中英文形式
  210. {
  211. printf("\n 中文形式 英文形式 ");
  212. printf("\n %-12s%12s", s[i].en, s[i].ch);
  213. index = i;
  214. }
  215. else if(strcmp(s[i].ch, ch) == 0)
  216. {
  217. printf("\n %-12s%12s", s[i].en, s[i].ch);
  218. index = i;
  219. }
  220. if(index == -1) //如果没找到该单词,下标仍为初始值-1
  221. {
  222. flag = 0;//让flag = 0; 表示没有该单词
  223. }
  224. if(!flag)
  225. printf("\n没有这个单词!");
  226. index = -1; //将index 和flag的值重新初始化为原来的值
  227. flag = 1;
  228. printf("\n继续查询请选1,返回上一级请选0:"); //选择是否继续查询
  229. scanf("%d", &choose);
  230. if(choose == 0)
  231. break;
  232. }
  233. break;
  234. case 2://查询该英文形式对应的单词
  235. while(1)
  236. {
  237. printf("\n请输入你要查询的单词英文形式:");
  238. scanf("%s", en);
  239. for(i=0; i<num; i++)//先找到该英文形式对应的序号
  240. if(strcmp(s[i].en, en) == 0)
  241. {
  242. printf("\n 中文形式 英文形式 ");
  243. printf("\n %-12s%12s", s[i].en, s[i].ch);
  244. index = i;
  245. }
  246. if(index == -1)
  247. {
  248. flag = 0;
  249. }
  250. if(!flag)
  251. printf("\n没有这个单词!");
  252. index = -1;
  253. flag = 1;
  254. printf("\n继续查询请选1,返回上一级请选0:");
  255. scanf("%d", &choose);
  256. if(choose == 0)
  257. break;
  258. }
  259. default:
  260. return;
  261. }
  262. }
  263. }
  264. //中译英测试
  265. void zytest()
  266. {
  267. char b1[20];
  268. int z;
  269. int choose=1;
  270. int i;
  271. //打开文件
  272. FILE *fp;
  273. while(choose)
  274. {
  275. fp=fopen("E:\\Repeat.txt","a+");
  276. if(!fp)
  277. {
  278. printf("\n打开文件失败");
  279. }
  280.  
  281. i = rand()%num;
  282. printf("\n【%s】请输入英文单词:",s[i].ch);
  283. scanf("%s",b1);
  284. for(z=0;strcmp(b1,s[i].en)!=0;z=z)
  285. {
  286. //回答错误时写入增强记忆文件
  287. fprintf(fp,"\n%s %s",s[i].en,s[i].ch);
  288. printf("\n输入错误!!请重新输入:");
  289. scanf("%s",b1);
  290. c=c+1;
  291. num++;//单词数目增加
  292. }
  293. fclose(fp);
  294. printf("\n恭喜你,回答正确,加10分!\n\n");d=d+1;
  295. printf("\n继续测试请选1,返回上一级请选0:");
  296. scanf("%d",&choose);
  297. if(choose==0)
  298. return;
  299. }
  300. }
  301. //英译中测试
  302. void yztest()
  303. {
  304. char b1[20];
  305. int z,x=41;
  306. int choose=1;
  307. int i;
  308. //打开文件
  309. FILE *fp;
  310.  
  311. while(choose)
  312. {
  313. i = rand()%num;
  314. fp=fopen("E:\\Repeat.txt","a+");//打开记忆文件
  315. if(!fp)
  316. {
  317. printf("\n打开文件失败");
  318. }
  319. printf("【%s】请输入中文意思:",s[i].en);
  320. scanf("%s",b1);
  321.  
  322. for(z=0;strcmp(b1,s[i].ch)!=0;z=z)
  323. {
  324. printf("输入错误!!请重新输入:");
  325. fprintf(fp,"\n%s %s",s[i].ch,s[i].en);
  326. scanf("%s",b1);
  327. c=c+1;
  328. num++;//文件中单词数目增加
  329. }
  330. fclose(fp);//关闭文件
  331. printf("\n恭喜你,回答正确,加10分!\n\n");d=d+1;
  332. printf("\n继续测试请选1,返回上一级请选0:");
  333. scanf("%d",&choose);
  334. if(choose==0)
  335. return;
  336. }
  337. }
  338. //增强错误单词的背诵功能
  339. void Repeat()
  340. {
  341. char b1[20];
  342. int z;
  343. int choose=1;
  344. int i;
  345. int n=0;
  346. int a;
  347. while(1)
  348. {
  349. printf("\n请输入1.英中错题复习 2.中英错题复习 0.退出");//选择
  350. scanf("%d",&a);
  351. switch(a)
  352. {
  353. case 1:
  354. while(1)
  355. {
  356. i=rand()%num;//从repeat.txt文件中随机拿出单词
  357. printf("[%s]请输入中文意思:",s[i].en);//输出英文单词,考查能否写出汉语意思
  358. scanf("%s",b1);
  359. for(z=0;strcmp(b1,s[i].ch)!=0;z=z)
  360. {
  361. printf("输入错误!!请重新输入:");
  362. scanf("%s",b1);
  363. c=c+1;//错题中我采用的是答错扣分,答对不加分的原则
  364. num++;//文件中单词数目增加
  365. }
  366. printf("\n恭喜你,回答正确!\n\n");
  367. printf("\n继续测试请选1,返回上一级请选0:");
  368. scanf("%d",&choose);
  369. if(choose==0)
  370. return;
  371. }break;
  372. case 2:
  373. while(1)
  374. {
  375. i=rand()%num;
  376. printf("[%s]请输入英文单词:",s[i].ch);//输出汉语意思,考查能否写出英文单词
  377. scanf("%s",b1);
  378. for(z=0;strcmp(b1,s[i].en)!=0;z=z)
  379. {
  380. printf("输入错误!!请重新输入:");
  381. scanf("%s",b1);
  382. c=c+1;
  383. num++;//文件中单词数目增加
  384. }
  385. printf("\n恭喜你,回答正确!\n\n");
  386. printf("\n继续测试请选1,返回上一级请选0:");
  387. scanf("%d",&choose);
  388. if(choose==0)
  389. return;
  390. }break;
  391. default:
  392. return;
  393. }
  394. }
  395. }
  396.  
  397. //成绩列表
  398. void list()
  399. {
  400. printf("\n 共计输入错误:%d次 **每次扣10分**\n",c);
  401. printf(" 共计输入正确:%d次 **每次加10分**\n",d);
  402. printf(" 你的总得分为:%d分\n\n",10*d-10*c);
  403.  
  404. }
  405. //词典维护
  406. void maintain()
  407. {
  408. int x=0;
  409. int choose;//维护功能选择
  410. printf(" ------------------\n");
  411. printf(" 1.增加单词\n");
  412. printf(" 2.修改单词\n");
  413. printf(" 3.删除单词\n");
  414. printf(" 4.查询单词\n");
  415. printf(" 5.退出本菜单\n");
  416. printf(" ------------------\n");
  417.  
  418. while(1)
  419. {
  420.  
  421. printf(" \n请输入维护功能编号:");
  422. scanf("%d",&choose);
  423.  
  424. switch(choose)
  425. {
  426. case 1:
  427. add();writefile();
  428. break;
  429. case 2:
  430. modify();writefile();
  431. break;
  432. case 3:
  433. del();writefile();
  434. break;
  435. case 4:
  436. search();
  437. break;
  438. case 5:
  439. return;
  440. default: printf("\n请在1-5之间选择");
  441. }
  442. }
  443. }
  444. //用户界面
  445. void menu()
  446. {
  447. int item;
  448. printf("\n");
  449. printf(" --------------------------------------------------------\n");
  450. printf(" - ---\n");
  451. printf(" - 英语单词小助手 --\n");
  452. printf(" - --\n");
  453. printf(" - 版本 : v2.0 --\n");
  454. printf(" - --\n");
  455. printf(" ---------------------------------------------------------\n");
  456. printf(" - --\n");
  457. printf(" - 1.词库维护 2.单词预览 --\n");
  458. printf(" - --\n");
  459. printf(" - 3.单词背诵(中英) 4.单词背诵(英中) --\n");
  460. printf(" - --\n");
  461. printf(" - 5.查询成绩 6.帮助 --\n");
  462. printf(" - --\n");
  463. printf(" - 7.错题复习 8.退出系统 --\n");
  464. printf(" ---------------------------------------------------------\n");
  465. printf("\n");
  466. printf(" - 请选择您需要的操作序号(1-8)按回车确认:");
  467.  
  468. scanf("%d",&item);
  469. printf("\n");
  470. readfile();
  471. switch(item)
  472. {
  473. case 1:
  474. maintain();
  475. break;
  476. case 2:
  477. show();
  478. break;
  479. case 3:
  480. zytest();
  481. break;
  482. case 4:
  483. yztest();
  484. break;
  485. case 5:
  486. list();
  487. break;
  488. case 6:
  489. help();
  490. break;
  491. case 7:
  492. readRepeatfile();
  493. Repeat();
  494. break;
  495. case 8:
  496. select =0;
  497. break;
  498. default:
  499. printf("请在1-8之间选择\n");
  500. }
  501. }
  502. int main()
  503. {
  504. while(select)
  505. {
  506. menu();
  507. }
  508. system("pause");
  509. return 0;
  510. }

四.经验归纳

这次的上机实验很有趣,但是也很高级,老师一开始就给了一个基本框架了,我只需要往里面增添,修改一些些就好了。

(1)首先,我把主界面的选择序号改了一点点,因为以我个人而言,我用不惯从0开始。也在里面根据我自己的理解,加了些注释。

(2)在search()函数中,因为一个相同的中文意思可能会有多个英语单词与之对应,原来的代码进行遍历之后就break了循环,自然只能查询到一个英文单词,我做的是遍历整个数组,同时用一个下标index = -1 进行标记,同时打印该单词的中英文,下标index的值改为当前数组的下标i ,继续遍历打印,同时标记,遍历完整个数组就可以打印多个拥有相同中文解释的不同的英文单词. 而index的作用就是,如果遍历完整个数组index仍等于-1,那么就说明没有查到该单词,可以进行查询为空的判断.

(3)在add()函数中,我添加了一个for循环,是录入单词变得更简洁了。

(4)我也加入了错题功能,在测试中,回答错误的单词会被加入在repeat.txt文件中,然后用随机数,抽取出来,再次回答,在这里,我改了一下下计分,在错题库的中出来重新回答的题目,答对不加分,答错还是会扣分,所以,还是最好有了没记住的单词 就赶快记下它哦。

(5)调试中发现我在search()中把s[i].en和s[i].ch给弄反了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/qq_44246262/article/details/89057231

延伸 · 阅读

精彩推荐