數據結構:反轉字符串(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
英文地址,請注明出處:http://en.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,但是對接的思路跟語言沒有關系,應該不盡相同; 小程序上手路線…