news 2026/5/1 8:10:11

GESP认证C++编程真题解析 | B3927 [GESP202312 四级] 小杨的字典

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
GESP认证C++编程真题解析 | B3927 [GESP202312 四级] 小杨的字典

​欢迎大家订阅我的专栏:算法题解:C++与Python实现!
本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战!

专栏特色
1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的代码实现与详细指导,帮助您夯实算法基础。
2.系统化学习路径:按照算法类别和难度分级,从基础到进阶,循序渐进,帮助您全面提升编程能力与算法思维。

适合人群:

  • 准备参加蓝桥杯、GESP、CSP-J、CSP-S等信息学竞赛的学生
  • 希望系统学习C++/Python编程的初学者
  • 想要提升算法与编程能力的编程爱好者

附上汇总帖:GESP认证C++编程真题解析 | 汇总


【题目来源】

洛谷:[B3927 GESP202312 四级] 小杨的字典 - 洛谷

【题目描述】

在遥远的星球,有两个国家 A 国和 B 国,他们使用着不同的语言:A 语言和 B 语言。小杨是 B 国的翻译官,他的工作是将 A 语言的文章翻译成 B 语言的文章。

为了顺利完成工作,小杨制作了一本字典,里面记录了N NN个 A 语言单词对应的 B 语言单词,巧合的是,这些单词都由地球上的 26 个小写英文字母组成。

小杨希望你写一个程序,帮助他根据这本字典翻译一段 A 语言文章。这段文章由标点符号!()-[]{}\|;:'",./?<>和一些 A 语言单词构成,每个单词之间必定由至少一个标点符号分割,你的程序需要把这段话中的所有 A 语言单词替换成它的 B 语言翻译。特别地,如果遇到不在字典中的单词,请使用大写 UNK 来替换它。

例如,小杨的字典中包含2 22个 A 语言单词abcd,它们的 B 语言翻译分别为adef,那么我们可以把 A 语言文章abc.d.d.abc.abcd.翻译成 B 语言文章a.def.def.a.UNK.其中,单词abcd不在词典内,因此我们需要使用 UNK 来替换它。

【输入】

第一行一个整数N NN,表示词典中的条目数。保证N ≤ 100 N \le 100N100

接下来N NN行,每行两个用单个空格隔开的字符串A AAB BB,分别表示字典中的一个 A 语言单词以及它对应的 B 语言翻译。保证所有A AA不重复;保证A AAB BB的长度不超过10 1010

最后一行一个字符串S SS,表示需要翻译的 A 语言文章。保证字符串S SS的长度不超过1000 10001000,保证字符串S SS只包含小写字母以及标点符号!()-[]{}\|;:'",./?<>

【输出】

输出一行,表示翻译后的结果。

【输入样例】

2 abc a d def abc.d.d.abc.abcd.

【输出样例】

a.def.def.a.UNK.

【算法标签】

《洛谷 B3927 小杨的字典》 #GESP# #2023#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;intn;// 字典条目数map<string,string>mp;// 字典:单词 -> 翻译intmain(){// 输入字典大小cin>>n;// 读入字典for(inti=1;i<=n;i++){string a,b;cin>>a>>b;// a: 单词, b: 翻译mp[a]=b;// 建立映射}// 输入待翻译的字符串string s;cin>>s;string t="";// 临时存储当前识别的单词inti;// 遍历输入字符串for(i=0;i<s.size();i++){// 如果是小写字母,加入到当前单词if(islower(s[i])){t+=s[i];}else{// 遇到非小写字母,表示单词结束if(t!=""){// 查找字典if(mp.count(t)){cout<<mp[t];// 输出翻译}else{cout<<"UNK";// 未知单词}t="";// 清空临时单词}// 输出当前的非字母字符(保持原样)cout<<s[i];}}// 处理末尾可能剩余的单词if(t!=""){if(mp.count(t)){cout<<mp[t];}else{cout<<"UNK";}}// 问题:这里输出s[i]会越界,因为循环结束i==s.size()// 应该是想要输出最后一个字符?但实际不应该在这里输出// cout << s[i]; // 这行应该删除return0;}

【运行结果】

2 abc a d def abc.d.d.abc.abcd. a.def.def.a.UNK.
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/28 17:08:50

LangFlow处理文件上传和解析的完整示例

LangFlow 处理文件上传与解析的完整实践 在智能应用开发日益普及的今天&#xff0c;如何让非技术人员也能快速构建具备文档理解能力的 AI 系统&#xff1f;这个问题在企业知识管理、教育辅助和自动化客服等场景中尤为突出。传统基于 LangChain 的解决方案虽然功能强大&#xff…

作者头像 李华
网站建设 2026/4/29 12:11:18

LangFlow社区推荐插件合集:提升开发效率的秘密武器

LangFlow社区推荐插件合集&#xff1a;提升开发效率的秘密武器 在AI应用爆发式增长的今天&#xff0c;构建一个能理解自然语言、调用工具、检索知识并生成专业回复的智能体&#xff0c;早已不再是仅靠写几行代码就能完成的任务。随着大语言模型&#xff08;LLM&#xff09;能力…

作者头像 李华
网站建设 2026/4/25 20:12:07

重症监护室环境监控系统设计(有完整资料)

资料查找方式&#xff1a;特纳斯电子&#xff08;电子校园网&#xff09;&#xff1a;搜索下面编号即可编号&#xff1a;T5322310M设计简介&#xff1a;本设计是重症监护室环境监控系统设计&#xff0c;主要实现以下功能&#xff1a;通过温湿度传感器检测温度和湿度 通过大气压…

作者头像 李华
网站建设 2026/4/25 12:14:09

LangFlow中文处理表现如何?实测结果告诉你

LangFlow中文处理表现如何&#xff1f;实测结果告诉你 在AI应用开发日益普及的今天&#xff0c;越来越多团队希望快速构建基于大语言模型&#xff08;LLM&#xff09;的智能系统。然而&#xff0c;即便是熟练的开发者&#xff0c;在面对复杂的LangChain调用链时也常常感到力不从…

作者头像 李华
网站建设 2026/4/18 9:55:15

汇编语言全接触-42.虚拟机管理器

虚拟机管理器(VMM)是Windows 95的实际操作系统&#xff0c;它建立和维护一个管理虚拟机的框架&#xff0c;同时为其他vxd程序提供许多重要的服务。其中三种重要的服务是&#xff1a; 内存管理 中断处理 线程调度 内存管理VMM使用Intel 80386或更新的处理器的内存调页能力来为系…

作者头像 李华
网站建设 2026/4/18 15:57:37

密钥泄露危机频发,Open-AutoGLM究竟如何构筑安全防线?

第一章&#xff1a;密钥泄露危机频发&#xff0c;安全防线何在近年来&#xff0c;随着云计算与微服务架构的普及&#xff0c;API 密钥、数据库凭证等敏感信息成为攻击者的主要目标。频繁曝光的密钥泄露事件不仅导致数据外泄&#xff0c;还引发大规模服务中断与经济损失。密钥管…

作者头像 李华