c语言 文件处理的问题:读入一篇英文短文文件,然后统计
读入一篇英文短文文件,统计分别以各英文字母开头的单词数,短文中的单词总数、句子总数、包含单词个数最多的句子中的单词数。假定单词之间有任意多个空白符、标点符号分隔,每个单词...
读入一篇英文短文文件,统计分别以各英文字母开头的单词数,短文中的单词总数、句子总数、包含单词个数最多的句子中的单词数。假定单词之间有任意多个空白符、标点符号分隔,每个单词仅由英文字母组成。
希望大神给出源代码 展开
希望大神给出源代码 展开
3个回答
展开全部
#include<stdio.h>
#include<string.h>
int num(char *str);
int juzs(char *str,int*p);
int main()
{
int word,jzs,max;
char a[10000];
printf("请输入英文文章:\n");
gets(a);
word=num(a);
jzs=juzs(a,&max);
printf("这篇文章中有%d个单词,有%d个句子,最长的句子中有%d个单词",word,jzs,max);
return 0;
}
int num(char *str)
{
int flag=0,i=0,j=0;
while(str[i]!='\0')
{
if(str[i]>='A'&&str[i]<='Z'||str[i]>='a'&&str[i]<='z')
flag++;
else flag=0;
if(flag==1)j++;
i++;
}
return j;
}
int juzs(char *str,int*max)
{
int i=0,flag=0,j=0,m=0;
*max=0;
while(str[i]!='\0')
{
while(str[i]!='.')
{
if(str[i]>='A'&&str[i]<='Z'||str[i]>='a'&&str[i]<='z')
m++;
else m=0;
if(m==1)(*max)++;
i++;
}
if(j<(*max))j=*max;
i++;
*max=0;
flag++;
}
*max=j;
return flag;
}
#include<string.h>
int num(char *str);
int juzs(char *str,int*p);
int main()
{
int word,jzs,max;
char a[10000];
printf("请输入英文文章:\n");
gets(a);
word=num(a);
jzs=juzs(a,&max);
printf("这篇文章中有%d个单词,有%d个句子,最长的句子中有%d个单词",word,jzs,max);
return 0;
}
int num(char *str)
{
int flag=0,i=0,j=0;
while(str[i]!='\0')
{
if(str[i]>='A'&&str[i]<='Z'||str[i]>='a'&&str[i]<='z')
flag++;
else flag=0;
if(flag==1)j++;
i++;
}
return j;
}
int juzs(char *str,int*max)
{
int i=0,flag=0,j=0,m=0;
*max=0;
while(str[i]!='\0')
{
while(str[i]!='.')
{
if(str[i]>='A'&&str[i]<='Z'||str[i]>='a'&&str[i]<='z')
m++;
else m=0;
if(m==1)(*max)++;
i++;
}
if(j<(*max))j=*max;
i++;
*max=0;
flag++;
}
*max=j;
return flag;
}
展开全部
可以用一个bool型函数利用ASCII码判断是否为字母,然后bool每从true到false转换一次让单词数加一。判断得到ASCII码为句号的让句子数加一。
至于如何判断bool有转换,可以在接受bool返回值的函数中订两个监视变量,每次将返回值赋给a,并且让b记录的是上一次的结果,判断a是否等于b。随后让b=a;
至于如何判断bool有转换,可以在接受bool返回值的函数中订两个监视变量,每次将返回值赋给a,并且让b记录的是上一次的结果,判断a是否等于b。随后让b=a;
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询