电子词典C语言实现
来源:互联网 发布:center os安装windows 编辑:程序博客网 时间:2024/06/05 16:24
- 电子词典的构成:
#兜圈子
Trans:go around in circles@circle@take a joy-ride@beat about the bush.
搜索字条用#开始占一行,翻译以Trans:开始占一行 - 电子词典搜索实现思路
- 打开电子词典读入内存中
- 输入查询单词输出对应结果
- 释放内存
- 循序实现
#define _CRT_SECURE_NO_WARNINGS#include <stdio.h>#include <stdlib.h>#include <string.h>#include <time.h>#define MAX 111111 //最大记录数struct dict{ char *key;//词条(搜索的内容) char *content;//词条对应的翻译};//打开字典文件,并读取文件内容,创建一个dict数组,key指向词条,content指向翻译int open_dict(struct dict **p, const char *dict_filename){ FILE *pfile = fopen(dict_filename, "r"); if (pfile == NULL) return 0;//打开文件失败,函数返回 *p = (struct dict *)malloc(sizeof(struct dict) * MAX);//固定分配MAX大小内存 memset(*p, 0, sizeof(struct dict) * MAX);//将分配内存初始化为0 struct dict *pD = *p;//pD指向数组p的首地址 char buf[1024] = { 0 }; size_t len = 0; int i = 0;//计数器 while (!feof(pfile))//循环读取文件,直到文件末尾 { memset(buf, 0, sizeof(buf)); fgets(buf, sizeof(buf), pfile);//读取文件一行 len = strlen(buf);//得到读取到字符串长度 if (len > 0) { pD[i].key = (char *)malloc(len);//根据字符串长度分配内存 memset(pD[i].key, 0, len); strcpy(pD[i].key, &buf[1]);//将读取到的内容拷贝到key中 } memset(buf, 0, sizeof(buf)); fgets(buf, sizeof(buf), pfile); len = strlen(buf); if (len > 0) { pD[i].content = (char *)malloc(len); memset(pD[i].content, 0, len); strcpy(pD[i].content, &buf[6]); } i++;//计数器加1 } fclose(pfile);//关闭字典文件 return i;//返回读取到的字典词条数}//根据关键字key,在字典中查找内容int search_dict(const struct dict *p, int size, const char *key, char *content){ int i = 0; for (i = 0; i < size; i++)//遍历字典 { if ((p[i].key == NULL) || (p[i].content == NULL)) continue; if (strncmp(p[i].key, key, strlen(key)) == 0) { strcpy(content, p[i].content); return 1;//找到符合条件记录,返回1 } } return 0;//没有找到符合条件记录,返回0}//释放内存void free_dict(struct dict *p, int size){ int i = 0; for (i = 0; i < size; i++)//循环释放key与content成员内存 { if (p[i].key) free(p[i].key); if (p[i].content) free(p[i].content); } free(p);//释放p内存}int main(int argc, char *args[]){ if (argc < 2) { printf("usage: %s dict-filename\n", args[0]); return 0;//参数不足,程序退出 } long start_ms = 0;//记录函数执行的开始时间 long end_ms = 0;//记录函数执行的结束时间 struct dict *p = NULL; start_ms = clock();//记录函数执行的开始时间,单位:毫秒 int size = open_dict(&p, args[1]);//根据命令行第一个参数做为字典文件名,打开字典文件 if (size == 0) return 0;//打开字典文件失败,程序退出 end_ms = clock();//得到系统当前时间,单位:毫秒 printf("open_dict used %ld ms\n", end_ms - start_ms);//打印函数执行时间,单位:毫秒 char key[1024]; char content[1024]; while (1) { memset(key, 0, sizeof(key)); memset(content, 0, sizeof(content)); scanf("%s", key);//从键盘得到用户输入 if (strncmp(key, "command=exit", 12) == 0) break;//退出循环 start_ms = clock(); if (search_dict(p, size, key, content))//根据用户输入,在字典中检索 { printf("%s", content); } else { printf("not found\n"); } end_ms = clock(); printf("search_dict used %ld ms\n", end_ms - start_ms);//打印函数执行时间,单位:毫秒 } start_ms = clock(); free_dict(p, size); end_ms = clock(); printf("free_dict used %ld ms\n", end_ms - start_ms);//打印函数执行时间,单位:毫秒 return 0;}
- 链表实现
#define _CRT_SECURE_NO_WARNINGS#include <stdio.h>#include <stdlib.h>#include <string.h>#include <time.h>struct dict{ char *key; char *content; struct dict *next;//指向链表下一个节点的指针};//打开字典文件,并读取文件内容int open_dict(struct dict **p, const char *dict_filename)//open dict.txt,and read dict{ FILE *pfile = fopen(dict_filename, "r");//只读方式打开文件 if (pfile == NULL) return 0;//打开文件失败,函数返回 char buf[2048] = { 0 }; size_t len = 0; int i = 0;//计数器,记录读到到的词条总数 *p = (struct dict *)malloc(sizeof(struct dict));//分配链表首节点内存 memset(*p, 0, sizeof(struct dict)); struct dict *pD = *p;//pD指向链表首地址 while (!feof(pfile))//循环读取文件,直到文件末尾 { memset(buf, 0, sizeof(buf)); fgets(buf, sizeof(buf), pfile);//读取文件一行 len = strlen(buf);//得到读取到字符串长度 if (len > 0) { pD->key = (char *)malloc(len);//根据字符串长度分配内存 memset(pD->key, 0, len); strcpy(pD->key, &buf[1]);//将读取到的内容拷贝到key中 } memset(buf, 0, sizeof(buf)); fgets(buf, sizeof(buf), pfile); len = strlen(buf); if (len > 0) { pD->content = (char *)malloc(len); memset(pD->content, 0, len); strcpy(pD->content, &buf[6]); } pD->next = (struct dict *)malloc(sizeof(struct dict));//为链表的下一个节点分配内存 memset(pD->next, 0, sizeof(struct dict)); pD = pD->next;//将pD指向下一个节点位置 i++; } fclose(pfile);//关闭字典文件 return i;//返回读取到的字典词条数}//根据关键字key,在字典中查找内容int search_dict(const struct dict *p, int size, const char *key, char *content){ const struct dict *pD = p; while (pD)//遍历字典 { if ((pD->key) && (pD->content)) { if (strncmp(pD->key, key, strlen(key)) == 0) { strcpy(content, pD->content); return 1;//找到符合条件记录,返回1 } } pD = pD->next;//指向链表下一个节点位置 } return 0;//没有找到符合条件记录,返回0}//释放链表内存void free_dict(struct dict *p, int size){ struct dict *pD = p; while (pD) { if (pD->key)//删除链表节点中key成员内存 free(pD->key); if (pD->content)//删除链表节点中content成员内存 free(pD->content); struct dict *tmp = pD->next;//保存链表下一个节点的地址 free(pD);//删除链表当前节点 pD = tmp;//p指向下一个节点的位置 }}int main(int argc, char *args[]){ if (argc < 2) { printf("usage: %s dict-filename\n", args[0]); return 0;//参数不足,程序退出 } long start_ms = 0;//记录函数执行的开始时间 long end_ms = 0;//记录函数执行的结束时间 start_ms = clock(); struct dict *p = NULL; int size = open_dict(&p, args[1]);//根据命令行第一个参数做为字典文件名,打开字典文件 if (size == 0) return 0;//打开字典文件失败,程序退出 end_ms = clock(); printf("open_dict used %ld ms\n", end_ms - start_ms);//打印函数执行时间,单位:毫秒 char key[502]; char content[1024]; while (1) { memset(key, 0, sizeof(key)); memset(content, 0, sizeof(content)); scanf("%s", key);//从键盘得到用户输入 if (strncmp(key, "command=exit", 12) == 0) break; start_ms = clock(); if (search_dict(p, size, key, content))//根据用户输入,在字典中检索 { printf("%s", content); } else { printf("not found\n"); } end_ms = clock(); printf("search_dict used %ld ms\n", end_ms - start_ms);//打印函数执行时间,单位:毫秒 }; start_ms = clock(); free_dict(p, size);//释放链表内存 end_ms = clock(); printf("free_dict used %ld ms\n", end_ms - start_ms);//打印函数执行时间,单位:毫秒 return 0;}
阅读全文
0 0
- 电子词典C语言实现
- C语言电子词典的实现
- C语言课程设计----电子词典
- 电子词典c语言图形界面
- C语言课程设计:小型电子词典
- 电子词典模拟软件 c语言源代码
- c语言写电子词典雏形算法
- C语言期末课程设计3.电子词典
- 第十九周—c语言 电子词典项目
- C语言 简单的在线电子词典
- 《C语言及程序设计》实践参考——电子词典
- C语言及程序设计进阶例程-14 开发一个电子词典
- SQLite实现在线电子词典
- 简易电子词典的实现
- 电子词典的实现
- 用链表实现电子词典
- 电子词典C++实现
- 第四周《C语言及程序设计》实践项目14 开发一个电子词典
- SSD的理解及应用
- ajax 异步验证
- Impala高性能探秘之Runtime Filter
- TCP通信过程大讨论
- 简单的浅拷贝和深拷贝
- 电子词典C语言实现
- 森林和二叉树的转化
- LeetCode 50. Pow(x, n)--幂实现
- opencv viz 模块的键盘操作 registerKeyboardCallback
- CodeForces Weakness and Poorness
- 在linux下图形界面和命令行界面的切换
- WEB 集群与负载均衡(一)基本概念
- 信号捕捉
- 598. Range Addition II