输入一个英文句子,长度不超过200个字符。其中可包含的符号只有逗号","和句号"."。
输出句子中最长的一个单词。如果有多个这样的单词,输出最后出现的。Input多组数据,每行为一个句子,其中符号"."不代表句子结束,譬如人名中可含有".”。Output每行一个最长单词。这里单词的定义是仅由连续的字母组成的字符串。Sample Input
输出句子中最长的一个单词。如果有多个这样的单词,输出最后出现的。Input多组数据,每行为一个句子,其中符号"."不代表句子结束,譬如人名中可含有".”。Output每行一个最长单词。这里单词的定义是仅由连续的字母组成的字符串。Sample Input
Good morning. Have a nice day.Sample Output
morning nice
#include<stdio.h>
#include<stdlib.h>
char* findmax(char s[]){
char* longest_word;
longest_word=(char*)malloc(201);
int max = 0, word_length = 0, p = 0, i = 0;//p是用来记录最长单词的位置
for(i=0; s[i]!='\0'; i++)
{
if(s[i]==' ' || s[i]==',' || s[i]== '.')
{//计算是否为最长的单词
if(max <= word_length)
{
max = word_length;
p = i;
}
word_length = 0;
}
else
{//如果i扫到的不是空格,那么开始计算单词的长度
word_length++;
}
}
if(max <= word_length)
{//最长的单词在结尾的情况
max = word_length;
p = i;
}
for(p-=max, i=0; max>0; max--, p++, i++)
{
longest_word[i] = s[p];
}
longest_word[i] = '\0';
return longest_word;
}
int main(){
char s[201];
while(gets(s))
{
char* longest_word = findmax(s);
printf("%s\n", longest_word);
free(longest_word);}
return 0;
}