数据结构:反转字符串(Reversing a String)

目录

方法一:双指针法 

方法二:辅助数组

方法对比总结:


问题定义

给定一个字符串,例如:

char str[] = "hello";

我们的目标是把它反转成:

"olleh"

📌 输入特点:

  • 字符串用 char 数组表示(C风格字符串)

  • 最后一个字符是 '\0'(空字符),表示字符串结束

(可以参考类似问题:数据结构:数组:反转数组(Reverse the Array)-CSDN博客 )

方法一:双指针法 

🧠 思路讲解:双指针对换法

我们从字符串两端出发,交换字符:

  1. 指针 left 指向开头(索引 0)

  2. 指针 right 指向结尾(索引为 length - 1,排除 '\0'

逐步交换:

  • str[left] ↔ str[right]

  • 然后 left++, right--

  • 重复,直到 left >= right

 代码实现

Step 1:计算字符串长度(不包括 '\0'

int len = 0;
while (str[len] != '\0') {len++;
}

Step 2:初始化左右指针

int left = 0;
int right = len - 1;

Step 3:循环交换字符

while (left < right) {char temp = str[left];str[left] = str[right];str[right] = temp;left++;right--;
}

完整代码实现

#include <iostream>
using namespace std;void reverseString(char str[]) {// 计算长度int len = 0;while (str[len] != '\0') {len++;}// 双指针交换字符int left = 0;int right = len - 1;while (left < right) {char temp = str[left];str[left] = str[right];str[right] = temp;left++;right--;}
}int main() {char str[] = "hello";cout << "原字符串: " << str << endl;reverseString(str);cout << "反转后: " << str << endl;return 0;
}

示例演示

字符串 "hello"

LeftRightstr[left]str[right]After swap
04'h''o'o e l l h
13'e''l'o l l e h
22--done

结果:"olleh"


方法二:辅助数组

我们使用辅助数组,不直接在原数组中改动。 

🧠 思路讲解(辅助数组方法)

  1. 首先求出原字符串长度(不包括 '\0');

  2. 创建一个新数组 rev[],长度为 len + 1,用于存放反转后的字符串;

  3. str[len - 1] 开始,把字符逐个写入 rev[0], rev[1], ..., rev[len - 1]

  4. 最后手动加上 rev[len] = '\0'

  5.  将 rev 再复制回 str,或者直接用 rev 输出。

代码实现

 Step 1:求字符串长度

int len = 0;
while (str[len] != '\0') {len++;
}

Step 2:创建新数组,反向拷贝字符

char rev[100]; // 足够大for (int i = 0; i < len; i++) {rev[i] = str[len - 1 - i];
}

Step 3:别忘了加终止符号 '\0'

rev[len] = '\0';

Step 4:把 rev 拷贝回原数组

for (int i = 0; i <= len; i++) {str[i] = rev[i];
}

完整代码如下

#include <iostream>
using namespace std;void reverseString(char str[]) {// Step 1: 求字符串长度int len = 0;while (str[len] != '\0') {len++;}// Step 2: 使用辅助数组从后往前复制char rev[100]; // 假设最多100个字符for (int i = 0; i < len; i++) {rev[i] = str[len - 1 - i];}// Step 3: 添加字符串终止符rev[len] = '\0';// Step 4: 将 rev 拷贝回原数组 strfor (int i = 0; i <= len; i++) {str[i] = rev[i];}
}int main() {char str[] = "hello";cout << "原字符串: " << str << endl;reverseString(str);cout << "反转后: " << str << endl;return 0;
}

方法对比总结:

方法说明时间复杂度空间复杂度
方法①:原地交换左右指针交换O(n)O(1)
方法②:辅助数组用新数组逆序写入O(n)O(n)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/90187.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/90187.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Redis Copy-on-Write机制:

Copy-on-Write机制&#xff1a; 父子进程共享内存页 当父进程修改数据时&#xff0c;内核会复制被修改的页 这可能导致内存使用量暂时增加 通俗的话描述一下可以用一个生活中的例子来通俗解释 Copy-on-Write&#xff08;写时复制&#xff09; 机制&#xff1a;&#x1f4d6; 比…

iOS加固工具有哪些?从零源码到深度混淆的全景解读

在iOS安全加固领域&#xff0c;不同项目类型对保护需求有着本质差异&#xff1a;“我有源码”与“我只有IPA”两条路径决定了你该用什么工具。本文将从 无需源码处理整个IPA包 到 源码级编译期混淆&#xff0c;分层探讨主流工具如何发挥价值&#xff0c;并附上适配方案建议。工…

Composer 可以通过指定 PHP 版本运行

是的&#xff0c;Composer 可以通过指定 PHP 版本运行&#xff0c;尤其是在服务器上有多个 PHP 版本时&#xff08;如 PHP 7.x 和 PHP 8.x&#xff09;。以下是几种常见方法&#xff1a;方法 1&#xff1a;使用 php 命令指定版本 Composer 依赖系统中的 php 命令&#xff0c;因…

vscode文件颜色,只显示自己更改的文件颜色

这个主要是因为你github git下来以后&#xff0c;用vscode打开会默认显示更改了&#xff0c;你只要在这里先手动取消更改就行了&#xff0c;注意不要把你自己更改的取消了

记录我coding印象比较深刻的BUG

4778&#xff1a;我的BUG噩梦问题描述&#xff1a;DAB播放中关ACC掉电后开ACC&#xff0c;手动切到FM/AM(有时第一次切换出现问题/有时第二次切换出现问题)&#xff0c;FM/AM不记忆关ACC前电台或者FM/AM关ACC掉电后开ACC&#xff0c;手动切到DAB再回到FM/AM&#xff0c;FM/AM不…

Kubernetes集群中Istio mTLS握手失败问题排查与解决方案

Kubernetes集群中Istio mTLS握手失败问题排查与解决方案 在微服务架构中&#xff0c;Istio 提供了基于 Envoy 的服务网格能力&#xff0c;其中 mTLS&#xff08;双向 TLS&#xff09;是确保服务间通信安全的重要机制。但在生产环境中&#xff0c;开发者常常会遇到 mTLS 握手失败…

antd+react+可输入的下拉选择组件

该组件是一个可输入的下拉选择组件&#xff0c;支持从预设选项中选择或手动输入自定义值。组件基于 React 和 Ant Design 实现&#xff0c;具有良好的交互体验和灵活的配置选项。 &#x1f9e0; 核心逻辑分析 1. 状态管理 const [isInput, setIsInput] useState(false); con…

React 面试题库

openAI React 面试题库 以下题库按模块分类&#xff08;React 架构与运行机制、核心 API、Diff 算法与事件机制、Fiber 架构与调度、并发模式与过渡、生命周期及新版生命周期对照、综合源码题、扩展专题、React 与 Vue 对比&#xff09;&#xff0c;并按难度&#xff08;初级…

查看两个tv and 手机模拟器的ip

要查看 Android 模拟器 的 IP 地址&#xff0c;你可以使用 ADB shell 命令来获取。下面是详细步骤&#xff1a;步骤 1&#xff1a;查看已连接的模拟器首先&#xff0c;确保你连接的模拟器已经启动并且连接到 ADB。你可以运行以下命令来查看已连接的设备&#xff1a;adb devices…

从零到一:用C语言构建贪吃蛇(一)- 基础框架与数据结构

资料合集下载链接: ​​https://pan.quark.cn/s/472bbdfcd014​ 第一步:绘制游戏世界 - 定义地图边界 任何游戏都需要一个舞台。在贪吃蛇中,这个舞台就是一个有明确边界的矩形地图。 1. 确定尺寸 根据笔记,我们首先要确定地图的尺寸。使用宏定义(​​#define​​)是…

AWS RDS 排查性能问题

AWS RDS 排查数据库问题 1.查看当前横在执行的SQL select id,user,time,left(info,100) from information_schema.processlist where time>0 and info is not null order by time desc ;2.AWS RDS 查看性能详情查看 Top SQL&#xff0c;AAS最高的几个sql&#xff0c;然后看这…

Baumer工业相机堡盟工业相机如何通过YoloV8深度学习模型实现持械检测(C#代码,UI界面版)

Baumer工业相机堡盟工业相机如何通过YoloV8深度学习模型实现持械检测&#xff08;C#代码&#xff0c;UI界面版&#xff09;工业相机使用YoloV8模型实现持械检测工业相机通过YoloV8模型实现持械检测的技术背景在相机SDK中获取图像转换图像的代码分析工业相机图像转换Bitmap图像格…

在 WPF 启动界面中心加载 GIF 动图

在 WPF 启动界面中心加载 GIF 动图 在 WPF 启动界面中心加载 GIF 动图可以通过多种方式实现。下面我将提供一个完整的解决方案&#xff0c;包括使用第三方库和纯 WPF 实现两种方法。 方法一&#xff1a;使用 WpfAnimatedGif 库&#xff08;推荐&#xff09; 这是最简单可靠的方…

Vue前端路由从入门到精通

目录 第1章:路由的本质与Vue Router的魅力 1.1 什么是前端路由? 1.2 为什么选择Vue Router? 1.3 快速上手:安装与基本配置 1.4 一个小实践:动态欢迎页 第2章:路由配置的进阶玩法 2.1 命名路由:给路由取个名字 2.2 动态路由的深度挖掘 2.3 嵌套路由:页面中的页面…

【Python】SQLAlchemy实现upsert

文章目录✅ 通用思路1. 使用 merge() 方法&#xff08;适用于简单场景&#xff09;2. 使用数据库特定的 UPSERT 功能&#xff08;推荐用于性能和并发安全&#xff09;&#x1f7e2; PostgreSQL: 使用 on_conflict_do_update&#x1f7e1; MySQL: 使用 ON DUPLICATE KEY UPDATE&…

快速入门SwiftUI

SwiftUI的入门难度稍微有点高&#xff0c;但对于比较熟悉Swift的UIKit老手来说阵痛期大概1周以内&#xff0c;两周内能达到UIkit的开发效率&#xff0c;个人总结快速入门路径如下&#xff1a; 第一步 周期&#xff1a;1天 操作&#xff1a;阅读苹果官方demo 目的&#xff1a;…

【n8n教程笔记——工作流Workflow】文本课程(第一阶段)——1、导航编辑器界面(Navigating the editor UI)介绍

https://docs.n8n.io/courses/ 文章目录Navigating the Editor UIGetting startedEditor UI settingsLeft-side panelTop barCanvasNodesFinding nodesAdding nodesNode buttonsSummaryNavigating the Editor UI In this lesson you will learn how to navigate the Editor UI…

【Altium Designer2025】电子设计自动化(EDA)软件——Altium Designer25版保姆级下载安装详细图文教程(附安装包)

今天给大家带来精心编写的Altium Designer2025版下载安装全流程图文指南&#xff0c;涵盖从系统准备到安装使用的完整过程。 教程严格遵循零广告、纯工具向原则&#xff0c;手把手教你如何正确安装并配置好这款强大的软件&#xff0c;让你快速进入电路设计的世界&#xff01; …

智象科技赋能金融、证券行业 IT 运维

一、金融、证券行业 IT 运维现状剖析 金融、证券行业 IT 系统架构极其复杂&#xff0c;业务对时效性和连续性的要求近乎苛刻&#xff0c;同时安全监管严格&#xff0c;这些特点共同催生了诸多运维痛点。 系统架构复杂 &#xff1a;IT 系统包含多个业务系统、数据平台和网络架构…

微信小程序服务端快速对接指南(java版)

背景说明 本文档旨在描述服务端在开发微信小程序时需要对接的小程序接口,以简要的方式描述对接流程、接口文档、使用场景。有些接口需要前后端配合,本文主要描述后端接口,对于前端仅轻轻点过。开发语言为Java,但是对接的思路跟语言没有关系,应该不尽相同; 小程序上手路线…