C語言實現(xiàn)英文單詞助手
英文單詞小助手的實現(xiàn)步驟,供大家參考,具體內(nèi)容如下
題目需求分析:
英文單詞小助手是幫助學(xué)生背誦單詞的軟件,用戶可以選擇背誦的詞庫,并可以編輯自己的詞庫,還應(yīng)有詞語預(yù)覽學(xué)習(xí)功能。系統(tǒng)可以給出中文,讓學(xué)生輸入其英文詞意,也可輸入英文讓學(xué)生輸入其中文詞意,并判定詞意是否正確。如不正確則給出提示并要求用戶重新輸入,如正確則加分。
根據(jù)題目需求,系統(tǒng)的基本功能如下。
(1) 詞庫維護:基于文件進行管理,可以增加、刪除和修改單詞的中英文詞意。每條記錄應(yīng)包括英文詞意、中文詞意。
(2) 單詞預(yù)覽:系統(tǒng)隨機顯示一條記錄,在屏幕上顯示中英文詞義。
(3) 中英單詞背誦:隨機顯示中文詞匯,用戶需輸入正確地英文詞意才可得分。如輸入錯誤則會提示用戶繼續(xù)輸入,直至輸入正確。
(4) 英中單詞背誦:隨機顯示英文詞匯,用戶需輸入正確的中文詞意才可得分。如輸入錯誤則會提示用戶繼續(xù)輸入,直至輸入正確。
(5) 成績查詢:顯示中英、英中背誦學(xué)習(xí)的成績統(tǒng)計。
(6) 幫助:通過幫助了解系統(tǒng)的功能與使用方式。
(7) 退出:退出系統(tǒng)。
具體實現(xiàn):
/**
* @file chapter.cpp
* @brief 英語單詞小助手
* @version 1.0
* @author Jack
* @date 2018年9月6日
*/
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAX_CHAR 20 // 最大字符
#define MAX_NUM 200 // 單詞的最大個數(shù)
/**
* @Description 單詞的結(jié)構(gòu)體
*/
struct word
{
char en[MAX_CHAR]; // 英文形式
char ch[MAX_CHAR]; // 中文形式
} s[MAX_NUM]; // 單詞數(shù)組
int num; // 單詞個數(shù)
int select = 1;// select為是否退出系統(tǒng)的標(biāo)記
int d = 0, c = 0;
/**
* @Description 幫助
*/
void help()
{
printf("\n本系統(tǒng)主要實現(xiàn)英語單詞學(xué)習(xí)的功能。用戶可對詞典文件中的單詞進行預(yù)覽,增刪改查。");
printf("\n同時還可進行中英、英中測試。本系統(tǒng)還提供了測試成績的顯示功能。");
}
/**
* @Description 從文件中讀取單詞的信息
*/
void readfile()
{
FILE *fp;
int i = 0;
fp=fopen("data.txt", "r");
if(!fp)
{
printf("\n打開文件data.txt失敗!");
}
while(fscanf(fp, "%s %s ", s[i].en, s[i].ch) == 2)
{
i++;
}
num = i;
if(0 == i)
printf("\n文件為空,請選擇詞典維護增加詞條!");
else
printf("\n");
fclose(fp);
}
/**
* @Description 向文件中寫入單詞的信息
*/
void writefile()
{
FILE *fp;
int i = 0;
fp=fopen("data.txt", "w");
if(!fp)
{
printf("\n打開文件data.txt失敗!");
}
for(i=0;i<num;i++)
{
fprintf(fp, "\n%s %s ", s[i].en,s[i].ch);
}
printf("\n");
fclose(fp);
}
/**
* @Description 按字典排序
*/
void sort()
{
int i,j;
char temp[MAX_CHAR];
for(i = 0;i < num - 1;i++)
{
for(j = num - 1;j > i;j--)
if(strcmp(s[j-1].en, s[j].en) > 0)
{
strcpy(temp, s[j-1].en);
strcpy(s[j-1].en, s[j].en);
strcpy(s[j].en, temp);
strcpy(temp, s[j-1].ch);
strcpy(s[j-1].ch, s[j].ch);
strcpy(s[j].ch, temp);
}
}
}
/**
* @Description 添加單詞信息
*/
void add()
{
int i=num,j,flag=1;
while(flag)
{
flag=0;
printf("\n請輸入單詞的英文形式:");
scanf("%s", s[i].en);
for(j = 0;j < i;j++)
if(strcmp(s[i].en, s[j].en) == 0)
{
printf("已有該單詞,請檢查后重新錄入!\n");
flag = 1;
break; /* 如有重復(fù)立即退出該層循環(huán),提高判斷速度 */
}
}
printf("\n請輸入單詞的中文形式:");
scanf("%s", s[i].ch);
num++;
printf("\n您輸入的信息為: 英文: %s 中文: %s ", s[i].en, s[i].ch);
sort();
}
/**
* @Description 刪除單詞信息
*/
void del()
{
int i = 0, j = 0;
char en[MAX_CHAR];// 英文形式
printf("\n請輸入你要刪除的單詞英文形式:");
scanf("%s", en);
for(i = 0;i < num;i++)// 先找到該英文形式對應(yīng)的序號
if(strcmp(s[i].en, en) == 0)
{
for(j = i;j < num - 1;j++)
s[j] = s[j+1];
num--;// 數(shù)量減少1
return;
}
printf("\n沒有這個單詞!");
}
/**
* @Description 修改單詞信息
*/
void modify()
{
int i = 0, choose = 0, flag = 1;// chooses代表選項標(biāo)識,flag代表是否找到單詞
char en[MAX_CHAR];// 英文形式
while(flag||choose)
{
printf("\n請輸入你要修改的單詞英文形式:");
scanf("%s", en);
for(i = 0;i < num;i++)// 先找到該英文形式對應(yīng)的序號
if(strcmp(s[i].en, en) == 0)
{
printf("\n請輸入單詞正確的英文形式:");
scanf("%s", s[i].en);
printf("\n請輸入此單詞正確的的中文形式:");
scanf("%s", s[i].ch);
printf("\n繼續(xù)修改請選1,返回上一級請選0:");
scanf("%d", &choose);
if(choose == 0)
return;
}
flag=0;
}
if(!flag)
printf("\n沒有這個單詞!");
}
/**
* @Description 單詞預(yù)覽
*/
void show()
{
int i = 0;
printf("\n單詞: 英文 中文 ");
for(i = 0;i < num;i++)
printf("\n %-12s%-12s", s[i].en, s[i].ch);
}
/**
* @Description 查詢單詞
*/
void search()
{
int i = 0, choose = 0, flag = 1,status = 0;
printf("請輸入查詢方式(1.按中文查詢 2.按英文查詢):");
scanf("%d", &status);
if(status == 1){
char ch[MAX_CHAR];// 中文形式
while(choose || flag)
{
printf("\n請輸入你要查詢的單詞中文形式:");
scanf("%s", ch);
for(i = 0;i < num;i++)// 先找到該中文形式對應(yīng)的序號
{
while(strcmp(s[i].ch, ch) == 0)
{
printf("\n英文形式 中文形式 ");
printf("\n %-12s%12s", s[i].en, s[i].ch);
i++;
}
}
printf("\n繼續(xù)查詢請選1,返回上一級請選0:");
scanf("%d", &choose);
if(choose == 0)
return;
flag = 0;
}
if(!flag){
printf("\n沒有這個單詞!");
}
}else{
char en[MAX_CHAR];// 英文形式
while(choose || flag)
{
printf("\n請輸入你要查詢的單詞英文形式:");
scanf("%s", en);
for(i = 0;i < num;i++)// 先找到該英文形式對應(yīng)的序號
if(strcmp(s[i].en, en) == 0)
{
printf("\n英文形式 中文形式 ");
printf("\n %-12s%12s", s[i].en, s[i].ch);
printf("\n繼續(xù)查詢請選1,返回上一級請選0:");
scanf("%d", &choose);
if(choose == 0)
return;
}
flag = 0;
}
if(!flag){
printf("\n沒有這個單詞!");
}
}
}
/**
* @Description 中英單詞背誦
*/
void zytest()
{
char b1[20];
int z;
int choose = 1;
int i;
int t;
while(choose)
{
i = rand() % num;
printf("\n【%s】請輸入英文單詞:",s[i].ch);
scanf("%s",b1);
for(z = 0;strcmp(b1, s[i].en) != 0;z = z)
{
printf("\n輸入錯誤??!請重新輸入:");
scanf("%s", b1);
c = c + 1;
t = 0;
}
printf("\n恭喜你,回答正確,加10分!\n\n");
d = d + 1;
if(t == 0){
printf("剛剛記錯的單詞是:%s,請再記一次!", s[i].en);
}
printf("\n繼續(xù)測試請選1,返回上一級請選0:");
t = 1;
scanf("%d", &choose);
if(choose == 0)
return;
}
}
/**
* @Description 英中單詞背誦
*/
void yztest()
{
char b1[20];
int z,x = 41;
int choose = 1;
int i;
i = rand() % num;
while(choose)
{
printf("【%s】請輸入中文意思:", s[i].en);
scanf("%s", b1);
for(z = 0;strcmp(b1, s[i].ch) != 0;z = z)
{
printf("輸入錯誤?。≌堉匦螺斎?");
scanf("%s", b1);
c = c + 1;
}
printf("\n恭喜你,回答正確,加10分!\n\n");
d = d + 1;
printf("\n繼續(xù)測試請選1,返回上一級請選0:");
scanf("%d", &choose);
if(choose == 0)
return;
}
}
/**
* @Description 成績列表
*/
void list()
{
printf("\n 共計輸入錯誤:%d次 **每次扣10分**\n", c);
printf(" 共計輸入正確:%d次 **每次加10分**\n", d);
printf(" 你的總得分為:%d分\n\n", 10 * d - 10 * c);
}
/**
* @Description 詞典維護
*/
void maintain()
{
int choose;// 維護功能選擇
printf(" ------------------\n");
printf(" 1.增加單詞\n");
printf(" 2.修改單詞\n");
printf(" 3.刪除單詞\n");
printf(" 4.查詢單詞\n");
printf(" 5.退出本菜單\n");
printf(" ------------------\n");
while(1)
{
printf(" \n請輸入維護功能編號:");
scanf("%d", &choose);
switch(choose)
{
case 1:
add();
writefile();
break;
case 2:
modify();
writefile();
break;
case 3:
del();
writefile();
break;
case 4:
search();
break;
case 5: return;
default:
printf("\n請在1-5之間選擇");
}
}
}
/**
* @Description 用戶界面
*/
void menu()
{
int item;
printf("\n");
printf(" *********************************************************\n");
printf(" # #\n");
printf(" # 英語單詞小助手 #\n");
printf(" # #\n");
printf(" # 版本 : v1.0 #\n");
printf(" # #\n");
printf(" *********************************************************\n");
printf(" # #\n");
printf(" # 0.詞庫維護 1.單詞預(yù)覽 #\n");
printf(" # #\n");
printf(" # 2.單詞背誦(中英) 3.單詞背誦(英中) #\n");
printf(" # #\n");
printf(" # 4.查詢成績 5.幫助 #\n");
printf(" # #\n");
printf(" # 6.退出系統(tǒng) #\n");
printf(" # #\n");
printf(" *********************************************************\n");
printf("\n");
printf(" 請選擇您需要的操作序號(0-5)按回車確認(rèn):");
scanf("%d", &item);
printf("\n");
readfile();
switch(item)
{
case 0:
maintain();
break;
case 1:
show();
break;
case 2:
zytest();
break;
case 3:
yztest();
break;
case 4:
list();
break;
case 5:
help();
break;
case 6:
select = 0;
break;
default:
printf("請在0-6之間選擇\n");
}
}
int main()
{
while(select)
{
menu();
}
system("pause");
return 0;
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
解讀堆排序算法及用C++實現(xiàn)基于最大堆的堆排序示例
把待排序的數(shù)組構(gòu)造出最大堆是進行堆排序操作的基本方法,這里將帶大家來解讀堆排序算法及用C++實現(xiàn)基于最大堆的堆排序示例,首先從堆排序的概念開始:2016-06-06
C語言數(shù)據(jù)結(jié)構(gòu)之循環(huán)鏈表的簡單實例
這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)之循環(huán)鏈表的簡單實例的相關(guān)資料,需要的朋友可以參考下2017-06-06
字符串中找出連續(xù)最長的數(shù)字字符串的實例代碼
這篇文章介紹了字符串中找出連續(xù)最長的數(shù)字字符串的實例代碼,有需要的朋友可以參考一下2013-09-09
VC++中HTControl控件類之CHTRichEdit富文本編輯控件實例
這篇文章主要介紹了VC++中HTControl控件類之CHTRichEdit富文本編輯控件,是一個比較實用的功能,需要的朋友可以參考下2014-08-08
C語言循環(huán)隊列與用隊列實現(xiàn)棧問題解析
循環(huán)隊列又叫環(huán)形隊列,是一種特殊的隊列。循環(huán)隊列解決了隊列出隊時需要將所有數(shù)據(jù)前移一位的問題,本篇帶你一起看看循環(huán)隊列的問題和怎樣用隊列實現(xiàn)棧2022-04-04
C語言雙指針多方法旋轉(zhuǎn)數(shù)組解題LeetCode
這篇文章主要為大家介紹了C語言雙指針使用多方法旋轉(zhuǎn)數(shù)組題解LeetCode,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步2022-02-02

