统计英文文件中单词数和各单词出现的频率(次数)

本程序通过C语言实现了一个简单的词频统计工具,能够从文本文件中读取数据,统计每个单词出现的频率,并按字典顺序输出结果。此外,程序还提供了添加文本、显示文本内容等功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/*
File name:词频统计.cpp
Author:杨柳
Date:2017.3.25
IDE:DEV-c++ 
*/
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAX_NUM 100000
struct Word      //单词结构体
{
int  num;//单词频数
char ch[20];//每一个单词
} word[MAX_NUM];
int select=1;//select 为是否退出系统的标记
 
//向用户提供帮助说明
void help()
{
    printf("\n(1)可导入任意英文文本文件");
	printf("\n(2)统计该英文文件中单词数和各单词出现的频率(次数),并能将单词按字典顺序输出");
	printf("\n(3)将单词及频率写入文件");
}

//获取英文文本信息及总单词数
void  readfile(char essay[],int total_num,char ch)

{
   FILE *fp;
   int i=1;
   fp=fopen("data.txt","r");
   if(!fp)
   {
	   printf("\n打开文件data.txt失败!");
	   exit(0);
   }
   ch=fgetc(fp);//ch为文章第一个字符,判断文章文件是否为空。
   if(ch!=EOF)
   {
     essay[0]=ch;
     for(i;!feof(fp);i++) //如果未遇到读入文本结束符
	 {
          essay[i]=fgetc(fp);//获取文章,将文章中的各个字符放到essay数组中
	 }
     essay[i]='\0';//在读取文章时,并没有将字符串的结束标志读进去,为了后面使用strtok等字符串的相关函数,加上’\0’。
     total_num=i;//记录单词的数量
   }
     if(0==i)
	   printf("\n文件为空,请选择英文文本输入!");
     else
	   printf("\n");
   fclose(fp);
 }


/*向文件写入英文文本信息*/
void  writefile(char essay[] ,int total_num, char ch)
{
    char essay_str[MAX_NUM];
    FILE *fp;
    char str=' ';
    getchar();
    int i=0;
    fp=fopen("data.txt","w");
    if(!fp)
    {
	   printf("\n打开文件data.txt失败!");
    }
    printf("请输入:");
    gets(essay_str);
    if(ch!=EOF)
    fputc(str,fp);
    fputs(essay_str,fp);//将新增的文章读到文件上
    strcat(essay,essay_str);
    readfile(essay,total_num,ch);
    printf("添加成功");
    printf("\n");
    fclose(fp);
}
 
//显示英文文本 
void show(char essay[],int total_num,char ch)//显示文章

{
   if(ch==EOF)
          printf("\n文件为空,请选择英文文本输入!");
   else
          printf("%s",essay);
          printf("\n");
}


/*按字典顺序进行单词排序*/
void sort(int k)
{
	int num;
	int i,j,t;  //定义局部变量i,j
	char temp[20];  //临时字符数组
	for(i=0;i<k-1;i++)
	{
		for(j=k-1;j>i;j--)
			if((strcmp(word[j].ch,word[j+1].ch)==1)) //比较两个单词,若后一个单词大于前一个,进行调换
			{
             strcpy(temp,word[j].ch);//交换单词
             strcpy(word[j].ch,word[j+1].ch);
             strcpy(word[j+1].ch,temp);
             t=word[j].num;//交换单词频数
             word[j].num=word[j+1].num;
             word[j+1].num=t;
			}
	}
} 
 
 
//统计单词频数
void count(char *essay,char *b)
{
  
int j,i=0;//i记录有多少不同的单词,n记录相同单词出现的次数

char *t;

bool judge=false;

int sum=0;

FILE *fp;

    for(t=strtok(essay,b);t!=NULL;t=strtok(NULL,b))

{

//利用strtok函数将文章中的单词分离开。

   sum++;//单词总数

   strcpy(word[i].ch,t);

   (word[i].num)=1;


   for(j=0;j<i;j++)

      if(strcmp(word[i].ch,word[j].ch)==0)

  {

      (word[j].num)++;

      judge=true;

  }

   if(judge)

   i--;

   i++;

   judge=false;

   }

   i=i-1;
   sort(i);
   printf("单词总数为:%d\n",sum);

   fp=fopen("count.txt","w");

    if(!fp)

    {

   printf("\n打开文件count.txt失败!");

   exit(0);

} 

   fprintf(fp,"单词总数为:%d\n",sum);////将单词总数读到文件中

   for(j=0;j<i;j++)

   {

   fprintf(fp,"%-16s\t%d\t\n",word[j].ch,word[j].num);//将单词、单词频数读到文件中

   printf("%-16s\t%d\t\n",word[j].ch,word[j].num);//将单词、单词频数打印到屏幕上

   }

    fclose(fp);

}

void menu()
{
    int item,total_num=0;//total_ch记录文章中的总字符数
    char b[20]={',','.','?',':','-',' '},essay[2*MAX_NUM],ch;
    printf("\n");
	printf("              *********************************************************\n");
	printf("              #                                                       #\n");
	printf("              #                 词频统计                              #\n");
	printf("              #                                                       #\n");
	printf("              *********************************************************\n");
	printf("              #                                                       #\n");
	printf("              #           1.显示英文文本                              #\n");
	printf("              #                                                       #\n");
	printf("              #           2.显示单词总数、全部单词及频数              #\n");
	printf("              #                                                       #\n");
	printf("              #           3.帮助                                      #\n");
	printf("              #                                                       #\n");
	printf("              #           4.输入英文文本                              #\n");
	printf("              #                                                       #\n");
	printf("              #           5.退出系统                                  #\n");
	printf("              *********************************************************\n"); 
    printf("请选择您需要的操作序号(1-5)按回车确认:");
    readfile(essay,total_num,ch);
    scanf("%d",&item);
    printf("\n");
   
    switch(item)
  {
   	  case 1:show(essay,total_num,ch);break;
      case 2:count(essay,b);break;
      case 3:help();break;
      case 4:writefile(essay,total_num,ch);break;
      case 5:select=0;break;
      default:printf("请在1-5之间选择\n");break;
   }
}

int main()
{ 
  	while(select)
	{
		menu();
	}
	return 1;
} 



 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值