- 输入一行字符,把字符串中最长的单词输出
- 思路:先找出每个单词的结束下标和单词长度存在数组中,根据最长单词的结束下标和长度,输出最长单词
int main()
{
char a[100];
int i;
int j;
int m=0,n=0;//用m来记录单词结束下标,用n来记录最长单词的长度
int b[100]={0};
printf("输入一个字符串:\n");
gets(a);
for(i=0,j=0;a[i]!='\0';i++){
if(a[i]!=' '&&i==0){ //说明一个单词开始
j=1;
}
else if(a[i-1]==' '&&a[i]!=' '&&i>0){ //说明一个单词开始
j=1;
}
else if((a[i]!=' '&&a[i+1]==' ')||(a[i]!=' '&&a[i+1]=='\0')){ //说明一个单词结束
if(n<j) {
n = j;
}
b[i] = n;
printf("%d %d\n",i,b[i]);
}
j++;
}
for(i=0;i<50;i++){
// printf("----b[%d]:%d\n",i,b[i]);
if(b[i]==n){
m = i;
break;
}
}
printf("m=%d,n=%d最长单词为:",m,n);
for(i=m-n+1;i<=m;i++){
printf("%c",a[i]);
}
}