题目描述
输入一个以’.'结尾的简单英文句子,单词之间用空格分隔,没有缩写形式和其它特殊形式;输出该句子中最长的单词。
关于输入
一个以’.'结尾的简单英文句子,单词之间用空格分隔,没有缩写形式和其它特殊形式,每个单词长度小于100,整个句子长度小于1000
关于输出
该句子中最长的单词。如果多于一个,则输出第一个
例子输入
I am a student of Peking University.
例子输出
University
源码实现
#include <iostream>
#include <string>
using namespace std;
int main()
{
int len = 0, symbol = 0, min = 100, max = 0, i, start;
string s, smax;
getline(cin, s);
for (i = 0; i < s.size(); i++) {
if (s[i] == ' ' || s[i] == ',' || i == s.size() - 1||s[i]=='.') {
start = i - len;
if (symbol == 0) {
if (len > max) {
max = len;
smax = s.substr(start, len);
}
len = 0;
}
symbol++;//指出现了一些奇怪的字符
}
else {
len++;
symbol = 0;
}
}
cout << smax << endl;
return 0;
}