题目:输入一行字符,用函数编程统计其中有多少个单词,假设单词以空格分开。
解析:
首先看到题目我的第一想法就是单词与单词之间使用空格联系的,那么也就是说每个单词必定之前有一个空格,也就是说有多少个空格与字母相连就有多少个单词(一个单词也算作字母,如a,I等)。那么就会出现一个问题,第一个单词怎么判断,例如:“空格”abcd”空格”def这样的话有两个格式是空格+字母这样就是2个单词。但是如果是abcd”空格“efg那么按照如上理论应该是1个单词,因为开头并不满足条件。
解决方法:
判断字符串第一个是不是字母,如果是字母那么单词个数从1开始计算,如果是空格则从0开始计算。
#include <stdio.h>
#include <stdlib.h>
#define N 40
int Select(char *a)
{
int flag;
if(*a==' ')
{
flag=0;
for(;*a!='\0';a++)
{
if(*a==' '&&((*(a+1)>='a'&&*(a+1)<='z')||(*(a+1)>='A'&&*(a+1)<='Z')))
flag++;
}
}
else if((*a>='a'&&*a<='z')||(*a>='A'&&*a<='Z'))
{
flag=1;
for(;*a!='\0';a++)
{
if(*a==' '&&((*(a+1)>='a'&&*(a+1)<='z')||(*(a+1)>='A'&&*(a+1)<='Z')))
flag++;
}
}
return flag;
}
int main()
{
char a[N];
gets(a);
int flag=Select(a);
printf("句子中共有%d个单词\n",flag);
return 0;
}
版权声明:本文为weixin_45535091原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。