代码解析:

引入了必要的头文件,包括iostream、string和sstream和vector头文件用于使用向量容器。

接下来,定义了一个getWords函数,该函数接受一个字符串sentence作为参数,并返回该字符串中的所有单词。在函数内部,使用字符串流istringstream将输入的句子分割为单词,并将每个单词存储在向量容器words中。

然后,定义了一个findLongestWord函数,它接受一个字符串向量words作为参数,并返回向量中最长的单词。在函数内部,使用一个循环遍历每个单词,并通过比较单词的长度大小来找到最长的那个单词。

还定义了一个findShortestWord函数,它接受一个字符串向量words作为参数,并返回向量中最短的单词。

在主函数main中,我们首先使用getline函数从标准输入中读取整行输入的句子,并将其存储在变量sentence中。

接下来,我们调用getWords函数将句子分割为单词,并将结果存储在向量words中。

然后,我们分别调用findLongestWord和findShortestWord函数来找到最长的单词和最短的单词,并将结果分别存储在longestWord和shortestWord变量中。

最后,我们使用cout对象依次输出最长的单词和最短的单词,并在行尾输出换行符。



参考代码:

#include <iostream>

#include <string>

#include <sstream>

#include <vector>

using namespace std;


vector<string> getWords(const string& sentence) {

    vector<string> words;

    istringstream iss(sentence);

    string word;

    while (iss >> word) {

        words.push_back(word);

    }

    return words;

}


string findLongestWord(const vector<string>& words) {

    string longestWord = "";

    for (const string& word : words) {

        if (word.length() > longestWord.length()) {

            longestWord = word;

        }

    }

    return longestWord;

}


string findShortestWord(const vector<string>& words) {

    string shortestWord = words[0];

    for (const string& word : words) {

        if (word.length() < shortestWord.length()) {

            shortestWord = word;

        }

    }

    return shortestWord;

}


int main() {

    string sentence;

    getline(cin, sentence);


    vector<string> words = getWords(sentence);


    string longestWord = findLongestWord(words);

    string shortestWord = findShortestWord(words);


    cout << longestWord << endl;

    cout << shortestWord << endl;


    return 0;

}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论