C语言实现文件单词统计

做了一个词频统计程序,该程序具有以下功能


(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);
}

你可能感兴趣的:(C语言实现文件单词统计)