C语言统计英语单词的个数
以下是我经过别人建议写的,还是不知哪里出错
#include <stdio.h>
#include <stdlib.h>
int main()
{
char a[80];
int i,num=0;
gets(a);
for(i=0;i<80;i++)
{
if( (a[i]<='z'&&a[i]>='a')||(a[i]<='Z'&&a[i]>='A')) continue;
if((( (a[i-1]<='z'&&a[i-1]>='a')||(a[i-1]<='Z'&&a[i-1]>='A'))||a[i-1]=='\0'))
num++;
}
printf("%d",num);
} 展开
C语言:统计输入的一行英文句子中的字母及单词个数,带注解!
//通过键盘输入一行英文句子,统计其中的英文字母和单词的数量,单词之间用空格分开(标点符号不算单词);
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
main()
{
char string[100];//根据拟从键盘输入的字串的长度需要适当调整,要避免输入的长度超出设定的范围。
char c;
int i, num=0,sum=0,word=0; //定义 word 用来指示一个单词是不是结束或新单词是否开始;
printf("请从键盘输入一行需要查询的英文句子,进行单词数量统计:\n\n");
gets(string); //从键盘获得输入的字符串;
//以下统计句子中的英文字符个数;
for(i=0;(c=string[i])!='\0';i++) //for循环语句,遍历句子中的每个字符;初始化i=0;若字符c!='\0',即未到达结束符'\0'的话,执行i++;
{
if(('A'<=string[i]&&string[i]<='Z')||('a'<=string[i]&&string[i]<='z'))
sum++; //以上为条件句,如果字符在A~Z,a~z 范围之内的话,则执行sum++,累加英文字母个数;
}
//以下统计句子中的英文单词个数;
for(i=0;(c=string[i])!='\0';i++) //for循环语句,遍历句子中的每个字符;初始化i=0;若字符c!='\0',即未到达结束符'\0'的话,执行i++;
{ //'\0'用作字符串的结束符。它的ASCII数值是0。
if(c<'A'||c>'Z'&&c<'a'||c>'z') //设定条件:如果字符 c 遇到A~Z和a~z范围之外其它符号字符的话,包括遇到空格' ';
word=0; //上面条件为真时,执行这里,置word=0,表示未遇到单词,或,一个单词已结束,同时也意味着要开始遇到下一个新单词;
else if(word==0) //当条件(word==0)为真,执行下面花括号里面的语句;当word==0时,表示未遇到字母,即未遇到单词,或上一个单词已结束;
{
word=1; //那么置word=1,即,表示下一个新单词开始,
num++; //执行num++,累加英文单词的个数;
}
}
printf("\n");
printf("您输入的这句英文句子中共包含%d个英文字符,%d个英文单词。\n",sum,num);
}
示例:输入语句: Hello ! My friend , how are you ? (注意单词的前后有空格)
C语言进阶:[14]统计单词个数
对一段英文文章进行单词统计,如果刚接触这样的问题,感觉比较棘手。要把问题分解开,每一个小问题解决了,然后进行归并,大问题也就解决了。首先单词是以字符开始,并且连续个字符,直到下一个字符不是字符结束,并且这个字符不能是数字字符。核心问题就是找出一个单词。
查找单词的代码如下:
首先查询到第一字符,有可能是单词,然后连续查找字符,直到遇到第一个不是字符的字符,并且这个字符在本编程中是空字符和标点符号,还得考虑遇到字符串结束符\0。在代码中难得部分是字符串指针的处理即返回的是下一个可能是单词的查找开始位置。例如
h e l l o 空格 w o r l d
0 1 2 3 4 5 6 7 8 9 10
第一次查找,i值指向了空格即i=5,传过来的索引j指向h,即索引为0,那么结果j应该指向空格即j=5,表达式为j= j+ (i-(e的索引)1 + 1(数量差一)) = j+ i。主程序代码是:
主程序主要是调用单词查找函数,每次更新索引值,直到字符串查找完毕。
结果如下:
该程序的缺点是没有统计单词的开始和结束位置。
#include <stdlib.h>
int main()
{
char a[80];
int i,num=0;
gets(a);
for(i=0;a[i]!='\0';i++) //这里应该检查到串尾,字符串结束符是'\0'
{
if ( (a[i] >='a' && a[i] <='z') || (a[i] >='A' && a[i] <='Z') ) //如果是字母,则一直找到非字母(分隔符:符号,空格等)
{
do {
i++ ;
} while ( (a[i] >='a' && a[i] <='z') || (a[i] >='A' && a[i] <='Z') );
//记录一个单词
num++;
}
}
printf("%d\n",num);
return 0;
}
为什么这里 for(i=0;a[i]!='\0';i++) 是检测到'\0'? 那单词与单词之间的空格不是有 '\0' 这个吗?
还有这里不是很懂:if ( (a[i] >='a' && a[i] ='A' && a[i] <='Z') ) //如果是字母,则一直找到非字母(分隔符:符号,空格等) 这里不是应该加上continue吗? 如果是字母,是应该执行上面的 for ,还是执行下面的 i++ ?
单词与单词之间的空格不是有 '\0' 这个吗? 答:没有!字符串只有结尾处有'\0'!
如果遇到字母,说明是一个单词的开始,就一直向后找到下一个分隔符,才算是该单词的结束。
如果不是字母,说明是单词间的分隔符,就返回for循环,继续检查下一个单词。慢慢理解
#include <stdlib.h>
int main()
{
char a[80];
int i,num=0;
gets(a);
for(i=0;i<80;i++)
{
if( (a[i]<='z'&&a[i]>='a')||(a[i]<='Z'&&a[i]>='A')) continue;
if (a[i]=' ')
{
i++;
ifif( (a[i]<='z'&&a[i]>='a')||(a[i]<='Z'&&a[i]>='A'))// 当再次遇到字母时就计数
num++;
}
num++; //这是因为到了最后一个单词时 无法执行if( (a[i]<='z'&&a[i]>='a')||(a[i]<='Z'&&a[i]>='A')) num++;中的num++ 所以最后要加上。
}
printf("%d",num);
}
根据你的程序改的
<stdio.h>
#include
<stdlib.h>
int
main()
{
char
a[80];
int
i,num=0;
gets(a);
for(i=0;i<80;i++)
{
if(
(a[i]<='z'&&a[i]>='a')||(a[i]<='Z'&&a[i]>='A'))
continue;
if
(a[i]='
')
{
i++;
ifif(
(a[i]<='z'&&a[i]>='a')||(a[i]<='Z'&&a[i]>='A'))//
当再次遇到字母时就计数
num++;
}
num++;
//这是因为到了最后一个单词时
无法执行if(
(a[i]<='z'&&a[i]>='a')||(a[i]<='Z'&&a[i]>='A'))
num++;中的num++
所以最后要加上。
}
printf("%d",num);
}
根据你的程序改的
<stdio.h>
#include
<stdlib.h>
int
main()
{
char
a[80];
int
i,num=0;
gets(a);
for(i=0;a[i]!='\0';i++)
//这里应该检查到串尾,字符串结束符是'\0'
{
if
(
(a[i]
>='a'
&&
a[i]
<='z')
||
(a[i]
>='A'
&&
a[i]
<='Z')
)
//如果是字母,则一直找到非字母(分隔符:符号,空格等)
{
do
{
i++
;
}
while
(
(a[i]
>='a'
&&
a[i]
<='z')
||
(a[i]
>='A'
&&
a[i]
<='Z')
);
//记录一个单词
num++;
}
}
printf("%d\n",num);
return
0;
}