编写函数。求一个英文句子中最长的英文单词,要求在主函数中输入数据,并输出结果;
#include<stdio.h>
#include<string.h>
//实际上就是一个一个的字母进行遍历,根据非字母的进行间隔,比如空格;
//判断 当遇到不是单词的符号的时候就将单词的个数加一(用flag进行标记),并遍历这个单词的长度;
//且每次判断是单词的时候记录单词的首地址, 如果最后是 最长的就返回这个首地址;
//I love study and study love me
int main()
{
int i;
char str[100];
printf("请输入一句英文:\n");
int ifletter(char str);
int ifMaxLong(char str[]);
gets(str);
//ifletter(str[]);
//ifMaxLong(str);
printf("一句英文中单词最长的:\n");
for(i=ifMaxLong(str);ifletter(str[i]);i++)
printf("%c",str[i]);
return 0;
}
int ifletter(char c)//判断输入的是不是一个字母,返回是否是单词
{
if((c>='a'&&c<='z')||(c>='A'&&c<='Z'))
return 1;//是字母就返回1
else
return 0; //不是就返回0
}
int ifMaxLong(char str[])
{
int i;
int tlen=0;//记录当前单词的长度;
int Mlen=0;//用于保存最长的单词长度;
int place=0;//保存最长单词的起始位;
int flag=1;//用于标记新单词,1表示新单词的开始;
int point;//用于记录当前单词的位置;
for(i=0;i<=strlen(str);i++)
{
if(ifletter(str[i])==1)//是字母
if(flag==1)//是一个单词的首字母
{
tlen++;
point=i;
flag=0;
}
else
tlen++;//不是当前字母的首字母,当前单词的长度++;
else//不是字母。说明即将出现新的单词字母
{
flag=1;
if(tlen>Mlen)//如果当前记录的单词长度比最长的单词长;
{
Mlen=tlen;//长度交换
place=point;//当前单词首地址变成最长单词的首地址
tlen=0;//再把当前单词的长度归零;便于判断下一个单词
}
}
}
return place;
}