1143:最长最短单词

断了今生、忘了曾经 提交于 2020-02-05 07:50:20

【题目描述】

 输入1行句子(不多于200个单词,每个单词长度不超过100),只包含字母、空格和逗号。单词由至少一个连续的字母构成,空格和逗号都是单词间的间隔。

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

【输入】

一行句子。

【输出】

第1行,第一个最长的单词。

第2行,第一个最短的单词。

【输入样例】

I am studying Programming language C in Peking University

【输出样例】

Programming
I

【提示】

提示:

如果所有单词长度相同,那么第一个单词既是最长单词也是最短单词

 

#include <iostream>
#include <stdio.h>
#include <cstring>
int i;
#define A 9999
int main()
{
	using namespace std;
	char ch[A];
	gets(ch);
	int len=strlen(ch);
	int max_len=0,min_len=9999,sum=0;
	int positionmin,positionmax;

	ch[len]=' ';          //避免内存偶然性(万一ch[len]处也是字母就麻烦了)
	for(i=0;i<len;i++)
	{
		if(ch[i]!=' '&&ch[i]!=',')
		{
			sum++;
		}
		else if(sum>0)    //这个显得有点重要
		{
			if(sum<min_len)
			{
				min_len=sum;
				positionmin=i-min_len;
			}
			if(sum>max_len)
			{
				max_len=sum;
				positionmax=i-max_len;
			}
			sum=0;
		}
	}
	for(i=positionmax;i<positionmax+max_len;i++)
		cout<<ch[i];
	cout<<endl;
	for(i=positionmin;i<positionmin+min_len;i++)
		cout<<ch[i];
	cout<<endl;
	return 0;
}

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!