C语言统计不同单词个数编写一个程序,输入一个句子,然后统计出这个句子当中不同的单词个数。例如:对于句子“onelittletwolittlethreelittleboys”,总共有5个不同的单词:one,little,t
编写一个程序,输入一个句子,然后统计出这个句子当中不同的单词个数。例如:对于句子“one little two little three little boys”,总共有5个不同的单词:one, little, two, three, boys。
说明:(1)由于句子当中包含有空格,所以应该用gets函数来输入这个句子;(2)输入的句子当中只包含英文字符和空格,单词之间用一个空格隔开;(3)不用考虑单词的大小写,假设输入的都是小写字符;(4)句子长度不超过100个字符。
输入格式:输入只有一行,即一个英文句子。
输出格式:输出只有一行,是一个整数,表示句子中不同单词的个数。
输入样例:
one little two little three little boys
输出样例:
5
#include<stdio.h>
#include<string.h>
int is_same(char*str,char*s)
{
char*p;
char str2[100];
int flag=0;
strcpy(str2,s);//将内容复制到另一个数组中
p=strtok(str2," ");//目的是为了避免strtok函数对原来字符串的破坏!
while(p!=NULL)
{
if(strcmp(p,str)==0)//比较是否相同!
{
flag=1;
break;
}
p=strtok(NULL," ");
}
if(flag==0)
return 0;
else
return 1;
}
int getcount(char*s)
{
int i=0,j=0,length=0;
char str[20],str1[100];//将前一个单词储存起来,以便与后面的单词比较看是否一样
int word_count=0;//统计单词个数
int k=0;//每个单词的字符数量!
while(s[i])
{
if(s[i]!=' ')
{
if(word_count==0)
word_count++;
j=i;
for(k=0;k<i;k++)
str1[k]=s[k];
str1[k]='\0';
while((s[j]!=' ')&&(s[j]!='\0'))
{
str[length]=s[j];
j++;
length++;
}
str[length]='\0';
if((word_count!=0)&&(!is_same(str,str1)))
{
word_count++;
}
i+=length;
}
else
i++;
length=0;
}
return (word_count-1);//减去第一次统计重复的
}
int main(void)
{
char str[100];
int count=0;
printf("input a string :");
gets(str);
count=getcount(str);
printf("不同单词的数量:%d\n",count);
return 0;
}
以下说法正确的是()A.氢原子的能量是量子化的B.在核反应过程中,质子数守恒C.半衰期越大,原子核 2020-04-08 …
在DSS中,为决策者提供使用系统的接口的部件是A.对话子系统B.数据库子系统C.模型子系统D.方法库 2020-05-23 …
建立一个实用的决策支持系统的先决条件是A.实现对话子系统B.建立数据库子系统C.建立模型库子系统 2020-05-23 …
新市场的长期预测功能属于A.战略计划子系统B.执行控制子系统C.管理控制子系统D.高层管理子系统 2020-05-23 …
Linux内核管理系统不包括的子系统是( )。A.进程管理子系统B.内存管理子系统C.文件管理子系统 2020-05-23 …
在系统结构方面,决策支持系统区分一般信息系统的关键,是它有()A.数据子系统B.模型库子系统C.用户 2020-05-23 …
在系统结构方面,决策支持系统区分一般信息系统的关键,是它有A.数据库子系统B.模型库子系统C.用户 2020-05-23 …
在系统结构方面,决策支持系统区分一般信息系统的关键是它有()。A.数据库子系统B.模型库子系统C.用 2020-05-24 …
下列说法中错误的是()A.人身体可看作是一个系统B.大肠杆菌菌落属于生命系统的种群层次C.一个分子 2020-07-15 …
中国第一个系统化的儒家版本是:()A孔子B孟子C荀子D董仲舒中国第一个系统化的儒家版本是:()A孔 2020-07-28 …