做了一个词频统计程序,该程序具有以下功能
(2)统计该英文文件中各单词出现的频率(次数),并能将单词按字典顺序输出。
本程序有很多功能没有实现,缺点是不能在文件输出。编写时间过于仓促,以后会逐步完善。
(1)可导入任意英文文本文件
(2)统计该英文文件中各单词出现的频率(次数),并能将单词按字典顺序输出。
本程序有很多功能没有实现,缺点是不能在文件输出。编写时间过于仓促,以后会逐步完善。
//**************英语单词词频统计**************
//作者:Linx-huo
//版本:v1.0
//创建时间:2017/04/01
//主要功能:统计任意文件中的英文单词个数排序输出
//
//****************************************
#include "stdio.h"
#include "stdlib.h"
#include "string.h"
typedef struct SWord
{
char word[201];
int count;
struct SWord* next;
}SWord;
void Add(SWord* Head,char* str)
{
SWord* tW;
SWord* p = Head;
while(1)
{
if (strcmp(p->word,str)==0)
{
p->count++;
return;
}
else
{
if (p->next != NULL)
{
p = p->next;
}
else
{
tW = (SWord *)malloc(sizeof(SWord));
memset(tW,0,sizeof(SWord));
sprintf(tW->word,"%s",str);
tW->count++;
p->next = tW;
return;
}
}
}
}
void Delete(SWord* Head)
{
SWord* tW;
SWord* pPrev = Head;
while(1)
{
if (pPrev!=NULL)
{
tW = pPrev->next;
free(pPrev);
pPrev = tW;
}
else
{
break;
}
}
}
void Disp(SWord* Head)
{
SWord* pWord;
for (pWord = Head->next;pWord!=NULL;pWord = pWord->next)
{
printf("%s:%d\n",pWord->word,pWord->count);
}
}
void main()
{
FILE* fp;
char str[201];
SWord * Head;
Head = (SWord *)malloc(sizeof(SWord));
memset(Head,0,sizeof(SWord));
fp = fopen("data.txt","r");
while(fscanf(fp,"%s",str)!=EOF)
{
Add(Head,str);
}
fclose(fp);
Disp(Head);
Delete(Head);
}