码迷,mamicode.com
首页 > 其他好文 > 详细

写一个函数,找出一个英文句子中的最长单词

时间:2020-12-02 12:15:35      阅读:5      评论:0      收藏:0      [点我收藏+]

标签:单词   div   print   rgb   nbsp   个数   span   main   扫描   

之前程序实验课上遇到的一道题,由于没做出来,这里有答案后在此记录一下

这里答案是非函数的方法做的,后面我自己尝试着给改成了函数

#include <stdio.h>
#include <string.h>
int main()
{
 char str[233]; //自定义一个数组 
 printf("输入所要查询的句子\n");//输入字符串 
 gets(str);
 int i,a,b,c;
 a=b=c=0;//初始化a,b,c为0,a为已经扫描过的单词的当初,b为正在扫描的单词的长度 
 for(i=0;i<strlen(str);i++)//设置循环进行扫描空格字符 
 {
   if(str[i]!= )//当数组中对应元素不是空格字符时 b的数值加1,进行计数 
   {
    b++;
    if(a<=b)//将b于a的值进行比较,b大于a,则将b的值赋给a,并通过c来计算最长单词的起始位置 
    {
      a=b;
     c= i-a+1;
    }
    continue;//当成条件后终止此次循环 
   }
   else //否则则将扫描后的b归零 
   {
    b=0;
   }
 }
 printf("最长单词是\n");//输出最长单词 
 for(i =c;i<c+a;i++)
  printf("%c",str[i]);
}

这个代码其实写出来到不算是难,但是细节的处理很重要,就比如最后那个else和b=0,我是万万没有考虑到的

后面我改成了函数

具体代码如下:

#include <stdio.h>
#include <string.h>
int findword(char a[]);//函数声明 
int main()
{
    char a[100];
    gets(a);
    int beginning;
    beginning=findword(a);
    while(a[beginning]!= ){//从最长单词的首字符开始输出,遇到空格字符时停止 
    printf("%c",a[beginning]);
    beginning++;}
    
    
}
int findword(char word[]){//这里findword单词记录的仅仅是最长单词的起始字符。 
    int n,i,a,b,c;
    a=b=c=0;
    n=strlen(word);
    for(i=0;i<n;i++){
        if(word[i]!= ){//遇到非空格字符时,b的数值加一 
            b++;//b用来储存当前单词的长度,切记清零 
        if(a<=b){//a用来储存扫描到的较长单词 
            a=b;
            c=i-a+1;//用c来记录最长单词的起始位置 
        }
        continue;//这里没有continue可能会导致else和第一个if语句同时执行,导致程序出错 
        }
        else b=0;//如果得到的a>b,将b清零,用来记录下一个单词长度,否则b的值会一直增加,导致输出结果错误
    }
    return c;
}

由于能力有限,我这个定义的函数就是仅仅把最长单词的首字符作为返回值,后面用while语句来输出。然而函数中其实已经把最长单词的长度求出来了,这点应该可以采用数组作为返回值的方法来处理,但是毕竟能力有限,姑且采用了这么一个不着调的处理方法。

 

写一个函数,找出一个英文句子中的最长单词

标签:单词   div   print   rgb   nbsp   个数   span   main   扫描   

原文地址:https://www.cnblogs.com/sz2003/p/14048843.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!