写一程序,输入一行字符,将此字符串中最长的单词输出的问题
#include <stdio.h>
main()
{
int alphabetic(char);
int longest(char []);
int i;
char line[100];
printf("Input one line:\n");
gets(line);
printf("The longest word is :");
for(i=longest(line);alphabetic(line[i]);i++)
printf("%c",line[i]);
printf("\n");
}
int alphabetic(char c)
{
if(c>='a'&&c<='z'||c>='A'&&c<='Z')
return(1);
else
return(0);
}
int longest(char string[])
{
int len=0,i,length=0,flag=1,place=0,point;
for(i=0;i<=strlen(sting);i++) /*若结束条件改为string[i]!='\0'就出现问题*/
if(alphabetic(string[i]))
if(flag)
{
point=i;
flag=0;
}
else
len++;
else
{
flag=1;
if(len>=length)
{
length=len;
place=point;
len=0;
}
}
return(place);
}
大家帮我看看longest函数循环结束条件 个人认为for(i=0;i<=strlen(sting);i++)和for(i=0;string[i]!='\0';i++)实现的功能是一样的