输入一行字符,把字符串中最长的单词输出

  • 输入一行字符,把字符串中最长的单词输出
  • 思路:先找出每个单词的结束下标和单词长度存在数组中,根据最长单词的结束下标和长度,输出最长单词
#include<stdio.h>
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]);
      }
}

猜你喜欢

转载自blog.csdn.net/zuiziyoudexiao/article/details/79945936