C 언어 구현 파일 단어 통계

1783 단어
주파수 통계 프로그램을 만들었는데, 이 프로그램은 다음과 같은 기능을 가지고 있다.
(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
",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); }

좋은 웹페이지 즐겨찾기