假设英文句子中只有 “ ”“,”“.”三种标点符号。
#include <iostream>
#include <cstring>
using namespace std;
//查找字符串中最长的一个单词
void FindLongestWord(string &s){
int maxLength = -1;//保存最长字符串的长度
int cnt = 0;//保存word字符串的游标
char word[101],longest[101];//word保存遍历的单词,longest保存最长的单词
for(int i = 0; i < s.length(); i++){
if(s[i] != ' ' && s[i] != ',' && s[i] != '.'){
word[cnt++] = s[i];//保存单词
}
if(s[i] == ' ' || s[i] == ',' || s[i] == '.'){
if(maxLength < cnt){//如果是最长的单词,保存至longest中
maxLength = cnt;
for(int j = 0; j < maxLength; j++){
longest[j] = word[j];
}
}
cnt=0;
}
}
cout<<"原始字符串:\n"<<s<<endl;
cout<<"最长的单词:"<<endl;
for(int i = 0; i < maxLength; i++)
cout<<longest[i];
}
int main() {
string str;
getline(cin,str);
FindLongestWord(str);
return 0;
}
运行结果:
如有错误,欢迎指正!
2021.11.15 考研打卡