一个以‘.’结尾的简单英文句子,单词之间用空格分隔,没有缩写形式和其它特殊形式。
输入:
一个以‘.’结尾的简单英文句子(长度不超过500),单词之间用空格分隔,没有缩写形式和其它特殊形式。
输出:
该句子中最长的单词。如果多于一个,则输出第一个。
输入样例:
I am a student of Peking University.
输出样例:
University
答案:
#include<bits/stdc++.h>
using namespace std;
int main()
{
int max=0,ma,sum=0; // 1
string s; // 2
getline(cin,s);
for(int i=0;i<s.size();i++)
{
if(s[i]!=' '&&s[i]!='.') sum++;
else
{
if(sum>max)
{
max=sum;
ma=i-sum;
}
sum=0; //判断完了,sum置零
}
}
for(int i=ma;i<ma+max;i++) cout<<s[i];
return 0;
}
如果将1 2 放到主函数之外,不能用 max ,因为有max函数。