


/*
输入要求:若干个以空格分割的单词序列,单词的总数不超过1000个,每个单词的长度不超过20个英文字符。
这里单词不区分大小写,例如 Hello与hELLo被认为是相同的单词。
*/
#include <stdio.h>
#include <string.h>
#define M 1000
#define N 20
void main()
{
char str1[M][N];//单词字串结果存放数组
char str2[M];//输入串或者用char *str2也可,这样可以
int strC[M];//单词字串计数数组.对应每个单词串,拥有一个计算器
int i=0,j=0,k=0,t=0,x=0;
gets(str2);//接受行输入
t=strlen(str2)+1;//计算该行中总字符数
printf("输入字串为:%s\n",str2);
while(j<t)
{
for(;str2[j]==32;j++);//如果串中是空格,则拼命跳过,不计
while(k<N&&str2[j]!=32) //不是空格,且没有超出题目中的要求: 每个字串长度小于N.如果大于N,自动截除.
str1[i][k++]=str2[j++]; //将输入行字串分割存放到结果数组中
str1[i][k]='\0'; //如果该串原来大于20,会被自动截除
strC[i]=1; //计数
for(x=0;x<i;x++) //与前面的串比较
if(strncmp(str1[i],str1[x],N)==0)//调用库函数,不分大小写与前面的串相比,相同则返回0.
{
strC[x]++; //相同,计数器数组增加
i--; //该串为重复串,总串数不增加
break; //跳出for循环
}
i++; //无重复串,则总字串数增加
k=0;
}
printf("结果:\n");
t=0;
for(;t<i;t++)//不超出总串数
printf("%s,%d\n",str1[t],strC[t]);
}