【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
题目分析
解题思路
- 读取一整行输入的句子,包含单词、空格、逗号和句号
- 遍历句子中的每个字符:
- 遇到字母时,将其加入当前单词
- 遇到分隔符(空格、逗号或句号)时,判断当前单词:
- 如果当前单词长度大于最长单词,更新最长单词
- 如果当前单词长度小于最短单词,更新最短单词
- 清空当前单词,准备处理下一个单词
- 遍历结束后,还需要检查最后一个单词(如果句子不以分隔符结尾)
- 按要求格式输出最长和最短单词:
- 第一行输出最长单词
- 第二行输出最短单词
复杂度分析:
- 时间复杂度为 $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 进行授权