快译通
优质
小牛编辑
148浏览
2023-12-01
dict.txt
#aardvark
Trans:n. 土猪
#aardwolf
Trans:n. 土狼
#aasvogel
Trans:n. 秃鹰之一种
#abaci
Trans:n. 算盘
#aback
Trans:ad. 向后地;朝后地
预处理实现 dict.h
#pragma once
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
struct dict // 词典词条数据结构体
{
char *key; // 单词字符串的首地址
char *content; // 相应的翻译字符串的首地址
};
void format_string(char *str);
int get_dict_size(FILE *pfile);
//打开字典文件,并读取文件内容
int open_dict(struct dict **p, const char *dict_filename);
//根据关键字key,在字典中查找内容
int search_dict(const struct dict *p, int size, const char *key, char *content);
//释放内存
void free_dict(struct dict *p, int size);
功能函数实现 dict.c
#include "dict.h"
void format_string(char *str)//去掉字符串结尾的回车,空格字符
{
size_t i;
for(i = strlen(str) - 1; i >= 0; i--)
{
if (str[i] != '\n' && str[i] != ' ' && str[i] != '\r')
{
str[i + 1] = '\0';
break;
}
}
}
int get_dict_size(FILE *pfile)//得到字典文件中词条总数
{
if (pfile == NULL)
return 0;
int i = 0;
char buf[2048];
while (!feof(pfile))
{
fgets(buf, sizeof(buf), pfile);
fgets(buf, sizeof(buf), pfile);
i++;//读取两行后,计数器加1
}
return i;
}
//打开字典文件,并读取文件内容
int open_dict(struct dict **p, const char *dict_filename)
{
FILE *pfile = fopen(dict_filename, "r");
if (pfile == NULL)
return 0;//打开文件失败,函数返回
int dict_size = get_dict_size(pfile);//得到字典文件中词条总数
if (dict_size == 0)
return 0;
*p = (struct dict *)malloc(sizeof(struct dict) * dict_size);//根据字典文件词条总数分配内存
memset(*p, 0, sizeof(struct dict) * dict_size);//将分配内存初始化为0
char buf[2048] = { 0 };
size_t len = 0;
int i = 0;
fseek(pfile, 0L, SEEK_SET);//设置读取位置为字典文件开始
while (!feof(pfile))//循环读取文件,直到文件末尾
{
memset(buf, 0, sizeof(buf));
fgets(buf, sizeof(buf), pfile);//读取文件一行
len = strlen(buf);//得到读取到字符串长度
if (len > 0)
{
(*p)[i].key = (char *)malloc(len);//根据字符串长度分配内存
memset((*p)[i].key, 0, len);
format_string(buf);//去掉字符串结尾的空格和回车
strcpy((*p)[i].key, &buf[1]);//将读取到的内容拷贝到key中
}
memset(buf, 0, sizeof(buf));
fgets(buf, sizeof(buf), pfile);
len = strlen(buf);
if (len > 0)
{
(*p)[i].content = (char *)malloc(len);
memset((*p)[i].content, 0, len);
strcpy((*p)[i].content, &buf[6]);
}
i++;
}
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 (strcmp(p[i].key, 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内存
}
主函数实现 main.c
#include "dict.h"
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 dict_size = open_dict(&p, args[1]);//根据命令行第一个参数做为字典文件名,打开字典文件
if (dict_size == 0)
return 0;//打开字典文件失败,程序退出
end_ms = clock();
printf("open_dict used %ld ms\n", end_ms - start_ms);//打印函数执行时间,单位:毫秒
char key[2048];
char content[2048];
while (1)
{
memset(key, 0, sizeof(key));
memset(content, 0, sizeof(content));
fgets(key, sizeof(key), stdin);//从键盘得到用户输入
format_string(key);//去掉字符串结尾的空格和回车
if (strncmp(key, "command=exit", 12) == 0)
break;
start_ms = clock();
if (search_dict(p, dict_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, dict_size);//释放内存
end_ms = clock();
printf("free_dict used %ld ms\n", end_ms - start_ms);//打印函数执行时间,单位:毫秒
return 0;
}