当前位置: 首页 > news >正文

题解:洛谷 B4556 [GESP202606 三级] 字符转换

【题目来源】

洛谷:B4556 [GESP202606 三级] 字符转换 - 洛谷

【题目描述】

小杨同学有一串字符,里面可能有:

  • 大写字母,比如A AAB BBC CC
  • 小写字母,比如a aab bbc cc
  • 数字,比如0 001 112 22

现在小杨同学想把这串字符变一变,规则如下:

  1. 如果是大写字母,就变成对应的小写字母;
  2. 如果是小写字母,就变成对应的大写字母;
  3. 如果是数字,就变成*

请你按照这个规则,帮小杨把整串字符转换好。

【输入】

输入一共有2 22行。

第一行:一个整数,表示这串字符一共有多少个字符。

第二行:一串连续的字符,中间没有空格。

【输出】

输出转换后的字符。

注意:输出时字符之间不要加空格。

【输入样例】

5 aBc98

【输出样例】

AbC**

【核心思想】

  1. 问题分析:给定长度为n nn的字符串S SS,需要对每个字符进行分类转换:大写字母→ \to小写字母、小写字母→ \to大写字母、数字→ \to*。本质是字符级别的条件映射问题,根据字符的 ASCII 属性执行不同的转换规则。

  2. 算法选择

    • 逐字符分类转换:遍历字符串,利用字符分类函数islower()isupper()isdigit()判断类型,调用对应的大小写转换函数或替换为*
    • 原地修改:直接在原字符串上修改,无需额外空间
  3. 关键步骤

    • 读取输入n nn(字符串长度)和S SS
    • 遍历转换:对S SS的每个字符S i S_iSi
      • islower(S_i)为真:S i ← S_i \leftarrowSitoupper(S_i)(小写转大写)
      • 否则若isupper(S_i)为真:S i ← S_i \leftarrowSitolower(S_i)(大写转小写)
      • 否则:S i ← S_i \leftarrowSi*(数字等字符替换)
    • 输出结果:输出转换后的字符串S SS
  4. 时间/空间复杂度

    • 时间复杂度:O ( n ) O(n)O(n),遍历字符串一次,每个字符的分类和转换均为O ( 1 ) O(1)O(1)
    • 空间复杂度:O ( 1 ) O(1)O(1)(除输入字符串外),原地修改无需额外辅助空间
  5. 字符分类转换的核心思想

    • 类型三分支:将字符集划分为互斥的三个子集(小写字母、大写字母、其他),每个子集对应唯一的转换规则,通过if-else if-else链实现清晰的分支逻辑
    • ASCII 码运算touppertolower内部基于 ASCII 码的固定偏移(小写与大写相差32 3232)实现O ( 1 ) O(1)O(1)转换,也可手动通过S[i] ^= 32(仅对字母)实现
    • 原地覆盖策略:直接在原字符串上修改,避免创建新字符串带来的额外空间开销,符合"转换"而非"生成"的语义
    • 防御性编程:使用islower/isupper而非直接比较 ASCII 范围,代码可读性更强且能正确处理扩展字符集(尽管本题限定为字母和数字)
    • 适用于字符级别的条件替换、大小写互换、符号过滤等基础字符串处理问题

【算法标签】

#入门 #字符串入门

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;intn;// n: 字符串长度string s;// s: 需要转换的字符串intmain(){cin>>n>>s;// 读入字符串长度和字符串本身for(inti=0;i<s.size();i++)// 遍历字符串中的每个字符{if(islower(s[i]))// 如果是小写字母s[i]=toupper(s[i]);// 转换为对应的大写字母elseif(isupper(s[i]))// 如果是大写字母s[i]=tolower(s[i]);// 转换为对应的小写字母else// 如果是数字等其他字符s[i]='*';// 替换为 '*'}cout<<s<<endl;// 输出转换后的字符串return0;}

【运行结果】

5 aBc98 AbC**
http://www.cnnetsun.cn/news/3150836.html

相关文章:

  • 第一线 DYXnet:海外企业跨境网络建设,为什么更需要“云网安”一体化服务商?
  • CountDownLatch 实现精准的并发控制
  • 商用烤盘定制厂家正规机构
  • 从 OC 平滑迁移 Swift 完整方案
  • VIbe Coding时期,推送项目惹众宾欢也
  • 小红书数据采集终极指南:Python xhs库完整实战教程
  • DeepSeek API 零基础接入指南:从 VS Code 插件到命令行调用
  • python神经网络编程入门(一)—— 分类器
  • 另类手搓大模型
  • 正版terraria怎么联机,正版terraria要怎么和朋友联机
  • 佛得角能够进入世界杯16强给我们的启示
  • 用运筹学与强化学习构建个人发展量化分析模型
  • 【全网最详细】Inventor 2027下载免费版 Inventor三维机械设计软件安装图解(2026最新)
  • 通信原理振幅调制解调电路仿真实操记录
  • USART通信详解:USART和UART区别、异步/同步模式、8N1、状态标志与调试方法
  • RAG 工程化实践:如何避免半成品文档进入在线召回
  • 微信 Dat 文件逆向分析:从 0x17CE 文件头到 PNG 图片的 3 步解密实战
  • 一次 Agent Run 是怎么发生的:从用户目标到工具调用、状态更新和风险拦截
  • STM32与H桥驱动芯片实现直流有刷电机高性能控制
  • 电机控制到底要学哪些东西?它不是一门课,而是一个交叉工程系统
  • 基于Codex与Claude的学术技能包:自动化科研工作流全解析
  • stortrace可视化分析:如何解读IO延迟热力图和时序图
  • 小米寥寥几家车企设计汽车顶棚
  • 速卖通商品信息自动翻译实现方案
  • 2026年AI论文软件测评:5款神器从大纲到答辩全链路通关攻略
  • 2026年靠谱AI论文软件全攻略(含保姆级操作教程)
  • WasmVideoPlayer:浏览器里直接播放H265视频
  • GitHub功能全览:含AI代码创作、多解决方案及汽车故障诊断音频ML项目
  • 性价比高的区域教育一体化管理平台哪个更完善
  • 云原生技术28-K8s排障实战:20个常见问题的快速定位与解决,从CrashLoopBackOff到Running的完整指南