#include
#include
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;