043:最长最短单词

043:最长最短单词
总时间限制: 1000ms 内存限制: 65536kB
描述
输入1行句子(不多于200个单词,每个单词长度不超过100),只包含字母、空格和逗号。单词由至少一个连续的字母构成,空格和逗号都是单词间的间隔。

试输出第1个最长的单词和第1个最短单词。

输入
一行句子。
输出
两行输出:
第1行,第一个最长的单词。
第2行,第一个最短的单词。
样例输入
I am studying Programming language C in Peking University
样例输出
Programming
I
提示
如果所有单词长度相同,那么第一个单词既是最长单词也是最短单词
代码

#include <iostream>
#include<cstring>
using namespace std;

int main(){
    char s[20000];
    int i=0,j=0; //j用来记录每个单词的长度
    int max=0,min=200;
    int n,m,t,maxbegin,minbegin;
    cin.getline(s,20000);
    t=strlen(s);
    while(s[i]!='\0')//遍历字符串 
    {
        if((s[i]!=' ')&&(i!=t-1)){j++;}//字符有三种情况:1非空格且非末尾 
        if(s[i]==' '){
           n=j;
           m=i-j;
           if(n>max){max=n;maxbegin=m;}
           if(n<min){min=n;minbegin=m;}
           j=0;}//2空格,遇到空格则切断并标记单词长度和起始位置,并将单词长度j置零 
        if(i==t-1){
           j++;
           n=j;
           m=i-j+1;
           if(n>max){max=n;maxbegin=m;}
           if(n<min){min=n;minbegin=m;}
           j=0;}//3末尾,遇到末尾则切断并标记单词长度和起始位置 
        i++;
    }
    for(int k=maxbegin;k<max+maxbegin;k++){
        cout<<s[k];
    }
    cout<<endl;
    for(int l=minbegin;l<min+minbegin;l++){
    cout<<s[l];
    }
    return 0;
}

注意:1.计算每个单词长度有两种方式,一是记录间隔位置,然后相减,但需要将字符串头尾各加一个空格,不然头尾容易出错;
二是直接记录单词长度,遇到空格或末尾的间隔,就重新记录长度;
2.直接记录单词长度,到最后一个字符时会有不同;
3.注意是i=strlen(s)-1,不是s[i]=strlen(s)-1;
4.运行时要关闭之前的运行窗口,不然会出错;
5.注意if(){}格式要完整。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 描述 输入1行句子(不多于200个单词,每个单词长度不超过100),只包含字母、空格和逗号。单词由至少一个连续的字...
    tingshuo123阅读 2,288评论 0 0
  • 参见贪心算法——最短路径Dijkstra算法参见动态规划 目录 0.最短路径问题0.1 最短路径问题描述 0.1....
    王侦阅读 4,889评论 1 9
  • 去年暑假高考的失败让我必须为争取一个报考本科机会再来一年,那时的我已充分了解高考的残酷与阴差阳错,曾经觉得并不遥远...
    d668576d9c90阅读 224评论 0 2
  • 三 这刻碑之人的家,就在城关镇院子旁边的小木房子,这不是什么“汤姆叔叔的小屋”,就是手工雕刻碑文的作坊。紫阳...
    TaraZhang阅读 287评论 0 1
  • 14天奇骑着摩托车来到了该市最大的娱乐城,门外的停车场早已爆满,吵闹的蹦迪声从一楼传了出来。昏暗的灯光下,混乱的舞...
    佛二代阅读 227评论 0 0