csp信奥赛C++高频考点专项训练之字符串 --【字符串基础】:输出亲朋字符串

csp信奥赛C++高频考点专项训练之字符串 --【字符串基础】:输出亲朋字符串

题目描述

亲朋字符串定义如下:给定字符串 s s s 的第一个字符的 ASCII 值加第二个字符的 ASCII 值,得到第一个亲朋字符; s s s 的第二个字符加第三个字符得到第二个亲朋字符;依此类推。注意:亲朋字符串的最后一个字符由 s s s 的最后一个字符 ASCII 值加 s s s 的第一个字符的 ASCII 值。

输入格式

输入一行,一个长度大于等于 2 2 2,小于等于 100 100 100 的字符串。

输出格式

输出一行,为变换后的亲朋字符串。输入保证变换后的字符串只有一行。

输入输出样例 #1
输入 #1
复制代码
1234
输出 #1
复制代码
cege
说明/提示

数据范围

保证字符串长度大于等于 2 2 2,小于等于 100 100 100。

样例解释

  • 字符 1 的 ASCII 值为 49;
  • 字符 2 的 ASCII 值为 50;
  • 字符 3 的 ASCII 值为 51;
  • 字符 4 的 ASCII 值为 52;

因此,可以得到:

  • 第 1 个亲朋字符:49 + 50 = 99,对应 c
  • 第 2 个亲朋字符:50 + 51 = 101,对应 e
  • 第 3 个亲朋字符:51 + 52 = 103,对应 g
  • 第 4 个亲朋字符:52 + 49 = 101,对应 e

思路分析

亲朋字符串的定义是:对于原字符串 s,长度为 n,生成一个新字符串,其中第 i 个字符(i 从 0 开始)的 ASCII 码等于:

  • i < n-1 时:s[i] + s[i+1]
  • i = n-1 时:s[n-1] + s[0]

因此只需遍历原字符串,依次计算相邻字符的 ASCII 值之和(最后一个与第一个相加),并将结果转换为字符输出即可。

代码实现

cpp 复制代码
#include<bits/stdc++.h> 
using namespace std;  

int main() {
    string s;  // 原字符串
    getline(cin, s); // 读取整行(允许空格)
    int n = s.size(); // 字符串长度
    for(int i = 0; i < n-1; i++) {  // 前 n-1 个亲朋字符
        cout << char(s[i] + s[i+1]);  // 相邻字符 ASCII 和转字符输出
    }
    cout << char(s[n-1] + s[0]); // 最后一个:末字符 + 首字符
    return 0;
}

功能分析

  1. 输入处理 :使用 getline 读取一行字符串,确保即使字符串中包含空格也能完整读入。
  2. 长度获取s.size() 得到字符串长度 n,满足题目给出的范围(2 ≤ n ≤ 100)。
  3. 核心计算
    • 循环 i 从 0 到 n-2,每次输出 (s[i] + s[i+1]) 对应的字符。
    • 循环结束后,单独计算并输出 (s[n-1] + s[0]) 对应的字符。
  4. 输出结果:所有字符连续输出,即得到亲朋字符串。

【完整系列请查看专栏】:
信奥赛C++普及组CSP-J一等奖通关刷题题单及题解:
https://blog.csdn.net/weixin_66461496/category_12673810.html 点击跳转


各种学习资料,助力大家一站式学习和提升!!!

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	cout<<"##########  一站式掌握信奥赛知识!  ##########";
	cout<<"#############  冲刺信奥赛拿奖!  #############";
	cout<<"######  课程购买后永久学习,不受限制!   ######";
	return 0;
}

【秘籍汇总】(完整csp信奥赛C++学习资料):

1、csp/信奥赛C++,完整信奥赛系列课程(永久学习):

https://edu.csdn.net/lecturer/7901 点击跳转

2、CSP信奥赛C++竞赛拿奖视频课:

https://edu.csdn.net/course/detail/40437 点击跳转

https://edu.csdn.net/course/detail/41081 点击跳转

3、csp信奥赛高频考点知识详解及案例实践:

CSP信奥赛C++动态规划:
https://blog.csdn.net/weixin_66461496/category_13096895.html点击跳转

CSP信奥赛C++标准模板库STL:
https://blog.csdn.net/weixin_66461496/category_13108077.html 点击跳转

信奥赛C++提高组csp-s知识详解及案例实践:
https://blog.csdn.net/weixin_66461496/category_13113932.html 点击跳转

4、csp信奥赛冲刺一等奖有效刷题题解:

信奥赛C++普及组CSP-J一等奖通关刷题题单及题解:
https://blog.csdn.net/weixin_66461496/category_12673810.html 点击跳转

信奥赛C++提高组csp-j初赛&复赛真题题解(持续更新): https://blog.csdn.net/weixin_66461496/category_12808781.html 点击跳转

信奥赛C++提高组csp-s初赛&复赛真题题解(持续更新):
https://blog.csdn.net/weixin_66461496/category_13125089.html 点击跳转

5、GESP C++考级真题题解:

GESP(C++ 一级+二级+三级)真题题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12858102.html 点击跳转

GESP(C++ 四级+五级+六级)真题题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12869848.html 点击跳转

GESP(C++ 七级+八级)真题题解(持续更新):
https://blog.csdn.net/weixin_66461496/category_13117178.html 点击跳转

· 文末祝福 ·

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	cout<<"跟着王老师一起学习信奥赛C++";
	cout<<"    成就更好的自己!       ";
	cout<<"  csp信奥赛一等奖属于你!   ";
	return 0;
}
相关推荐
WBluuue2 小时前
数据结构与算法:莫队(一):普通莫队与带修莫队
c++·算法
KuaCpp2 小时前
C++面向对象(速过复习版)
开发语言·c++
智者知已应修善业5 小时前
【51单片机不用数组动态数码管显示字符和LED流水灯】2023-10-3
c++·经验分享·笔记·算法·51单片机
AI进化营-智能译站6 小时前
ROS2 C++开发系列16-智能指针管理传感器句柄|告别ROS2节点内存泄漏与野指针
java·c++·算法·ai
报错小能手6 小时前
好好讲讲移动构造 移动赋值
c++
syker6 小时前
AIFerric深度学习框架:自研全栈AI基础设施的技术全景
开发语言·c++
xvhao20137 小时前
单源、多源最短路
数据结构·c++·算法·深度优先·动态规划·图论·图搜索算法
笑鸿的学习笔记8 小时前
qt-C++语法笔记之Qt Graphics View 框架中的类型辨析完全指南
c++·笔记·qt
山居秋暝LS8 小时前
安装C++版opencv和opencv_contrib
开发语言·c++·opencv