文章

【GESP】C++三级练习 luogu-B2121 最长最短单词

GESP三级练习,字符串练习(C++三级大纲中6号知识点,字符串),难度★★☆☆☆。

luogu-B2121 最长最短单词

题目要求

题目描述

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

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

输入格式

输入数据:一行句子。

输出格式

输出数据:

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

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

输入输出样例 #1

输入 #1

1
I am a student,i am studying Programming language C in Peking University.

输出 #1

1
2
Programming
I

题目分析

解题思路

  1. 读取一整行输入的句子,包含单词、空格、逗号和句号
  2. 遍历句子中的每个字符:
    • 遇到字母时,将其加入当前单词
    • 遇到分隔符(空格、逗号或句号)时,判断当前单词:
      • 如果当前单词长度大于最长单词,更新最长单词
      • 如果当前单词长度小于最短单词,更新最短单词
      • 清空当前单词,准备处理下一个单词
  3. 遍历结束后,还需要检查最后一个单词(如果句子不以分隔符结尾)
  4. 按要求格式输出最长和最短单词:
    • 第一行输出最长单词
    • 第二行输出最短单词

复杂度分析:

  • 时间复杂度为 $O(n)$,其中n为输入句子的总长度
  • 空间复杂度为 $O(m)$,其中m为最长单词的长度


示例代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#include <iostream>
#include <string>

int main() {
    // 定义输入字符串变量
    std::string str;
    // 读取一整行输入,包含空格
    std::getline(std::cin, str);
    // 获取字符串长度
    int length = str.length();
    // 初始化最大长度和最小长度
    int max_length = 0;
    int min_length = 100;
    // 存储最长和最短单词
    std::string str_max, str_min;
    // 当前单词字符计数
    int count = 0;
    // 遍历字符串的每个字符
    for (int i = 0; i < length; i++) {
        // 遇到分隔符(空格、逗号、句号)时处理当前单词
        if (str[i] == ' ' || str[i] == ',' || str[i] == '.') {
            // 跳过连续的分隔符
            if (count == 0) {
                continue;
            }
            // 更新最长单词
            if (count > max_length) {
                max_length = count;
                str_max = str.substr(i - count, count);
            }
            // 更新最短单词
            if (count < min_length) {
                min_length = count;
                str_min = str.substr(i - count, count);
            }
            // 重置计数器
            count = 0;
        } 
        // 处理最后一个字符
        else if (i == length - 1) {
            count++;
            // 更新最长单词
            if (count > max_length) {
                max_length = count;
                str_max = str.substr(i - count + 1, count);
            }
            // 更新最短单词
            if (count < min_length) {
                min_length = count;
                str_min = str.substr(i - count + 1, count);
            }
        } 
        // 累加字母计数
        else {
            count++;
        }
    }
    // 输出结果
    std::cout << str_max << std::endl;
    std::cout << str_min << std::endl;
    return 0;
}

所有代码已上传至Github:https://github.com/lihongzheshuai/yummy-code

GESP各级别考纲要点、知识拓展和练习题目清单详见C++学习项目主页

luogu-”系列题目已加入洛谷Java、C++初学团队作业清单,可在线评测,团队名额有限,欢迎加入。

bcqm-”系列题目可在编程启蒙题库进行在线评测。

本文由作者按照 CC BY 4.0 进行授权