#include<>
#include<>
#include<>
#define N 80
int fun(char *s)
{ char a='a';
int i,j,k,n=0;
i=strlen(s);
for(j=0;j<i;j++)
{
for(k=0;k<26;k++)
if(*(s+j)==(a+k)) //a+k,表示从a-z,26个字母遍历
n++; //*(s+j)表示字符串s的单个字符遍历
}
return n;
}
void main()
{
char line[N];
int num=0;
printf("Enter a string:\n ");
gets(line);
num=fun(line);
printf("The number of word is:%d\n\n ",num);
system("pause");
}
思路:
1.首先知道字符串的输入长度,其次知道如何能遍历单个字符。
2.对a-z中26个字母进行遍历。
3.再将26个字母依次与字符串单个字符进行比较查找,查找到的 +1,得出最终结果。
若是要查找输入的单词数量,程序如下:
int fun(char *s)
{
int i,j=0;
for(i=0;s[i]!='\0';i++)
if(s[i]!=' '&&(s[i+1]==' '||s[i+1]=='\0')) /*如果一个字母的下一个字符为空格或者结束标
记,则表示一个单词结束*/
j++;
return j; /*返回单词个数*/
}