一起學數據結構和算法(三)| 字符串(線性結構)

字符串(String)

字符串是由字符組成的有限序列,在計算機中通常以字符數組形式存儲,支持拼接、查找、替換等操作。


簡介

字符串是計算機科學中最常用的數據類型之一,由一系列字符組成的有限序列。在大多數編程語言中,字符串被作為基本數據類型或者對象提供,用于表示文本。從本質上講,字符串可以看作是一個數組,但與普通數組不同,字符串有特殊的屬性和操作方法,更適合處理文本數據。在 Java 等現代編程語言中,字符串是不可變的對象,一旦創建,其內容不可被修改。

核心特性

  1. 不可變性:在 Java 中,字符串一旦創建,其值不可被修改
  2. 字符序列:由多個字符按順序排列組成
  3. 索引訪問:可以通過索引訪問單個字符,索引從0開始
  4. 字符串池:Java 中常量字符串會被存儲在字符串中以節省內存
  5. Unicode支持:可以包含任何 Unicode 字符,支持多語言文本

基本操作

// 創建字符串
String greeting = "你好,世界!";
String name = new String("Java編程");// 字符串長度
int length = greeting.length();  // 6// 連接字符串
String message = greeting + " 歡迎學習" + name;
String sameMassage = greeting.concat(" 歡迎學習").concat(name);// 訪問字符
char firstChar = greeting.charAt(0);  // '你'// 獲取子字符串
String subStr = greeting.substring(0, 2);  // "你好"// 字符串比較
boolean isEqual = greeting.equals("你好,世界!");  // true
boolean ignoreCase = "Java".equalsIgnoreCase("java");  // true// 查找
int index = message.indexOf("歡迎");  // 返回"歡迎"在字符串中首次出現的索引
boolean contains = message.contains("Java");  // true// 替換
String newStr = greeting.replace('你', '我');  // "我好,世界!"// 分割
String[] parts = "蘋果,香蕉,橙子".split(",");  // ["蘋果", "香蕉", "橙子"]// 轉換大小寫(僅適用于拉丁字母)
String upper = "hello".toUpperCase();  // "HELLO"
String lower = "HELLO".toLowerCase();  // "hello"// 去除首尾空白
String trimmed = "  hello  ".trim();  // "hello"

優缺點

優點
  • 易用性:提供了豐富的 API 和操作方法,處理文本更方便
  • 國際化支持:支持 Unicode 字符集,可以處理各種語言的文本
  • 內存優化:字符串池機制減少內存使用

應用場景

  • 文本處理:處理用戶輸入,配置文件、日志等
  • 數據解析:解析 JSON、XML、CSV等格式的數據
  • 自然語言處理:文本分析、情感分析、機器翻譯等
  • 網絡通信:http 請求參數、URL處理、網絡協議等
  • 用戶界面:文本顯示、多語言支持等

擴展

StringBuilder、StringBuffer、String
  • String:不可變,適合作為常量使用
  • StringBuilder:可變,非線程安全,適合單線程下頻繁修改字符串
  • StringBuffer:可變,線程安全,適合在多線程環境使用,但性能略低于 StringBuilder

熱門題目

  • 14. 最長公共前綴
  • 20. 有效的括號
  • 415. 字符串相加
20. 有效的括號

給定一個只包括 ‘(’,‘)’,‘{’,‘}’,‘[’,‘]’ 的字符串 s ,判斷字符串是否有效。
有效字符串需滿足:
左括號必須用相同類型的右括號閉合。
左括號必須以正確的順序閉合。
每個右括號都有一個對應的相同類型的左括號。

示例:

輸入:s = “()”

輸出:true

題解

棧,后進先出(LIFO)

  1. 初始化一個空棧 stack
  2. 定義一個字典 mapping,用于記錄右括號與左括號的對應關系
  3. 遍歷字符串中的每一個字符:
    1. 如果是左括號,壓入棧
    2. 如果是右括號:
      1. 如果棧為空,說明沒有對應的左括號,返回 False
      2. 否則,彈出棧頂元素,比較是否是對應的左括號,不是則返回 False
  4. 遍歷結束后,檢查棧是否為空。如果棧為空,說明括號完全匹配,返回 True;反之說明有未匹配的左括號,返回 False
class Solution {public boolean isValid(String s) {// 使用 Deque 接口實現棧結構,效率優于 Stack 類Deque<Character> stack = new ArrayDeque<>();// 定義一個哈希表,用于存儲右括號到左括號的映射Map<Character, Character> mapping = new HashMap<>();mapping.put(')', '(');mapping.put('}', '{');mapping.put(']', '[');// 遍歷字符串中的每一個字符for (char c : s.toCharArray()) {// 如果當前字符是右括號if (mapping.containsKey(c)) {// 如果棧為空,說明沒有對應的左括號,直接返回 falseif (stack.isEmpty()) {return false;}// 彈出棧頂元素,并與當前右括號對應的左括號比較char top = stack.pop();if (mapping.get(c) != top) {return false;}} else {// 如果是左括號,直接壓入棧中stack.push(c);}}// 遍歷結束,如果棧為空,說明所有括號都正確匹配return stack.isEmpty();}
}

參考資料

[1] Hello 算法
[2] 算法導航

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/82639.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/82639.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/82639.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

2025電工杯數學建模競賽A題 光伏電站發電功率日前預測問題 保姆級教程講解|模型講解

完整內容請看文章最下面的推廣群 2025電工杯數學建模競賽 A題保姆級分析完整思路代碼數據教學 2025電工杯 A題保姆級教程思路分析 DS數模-全國大學生電工數學建模&#xff08;電工杯&#xff09; A題保姆級教程思路分析 A題&#xff1a;光伏電站發電功率日前預測問題 下面我…

React Native 拼音及拼音首字母搜索組件開發

寫在前面 “用戶說找不到聯系人&#xff1f;拼音搜索功能必須安排上&#xff01;” —— 當產品經理第N次提出這個需求時&#xff0c;我意識到需要開發一個強大的拼音搜索組件。本文將詳細介紹如何開發一個支持拼音匹配、首字母搜索的React Native搜索組件&#xff0c;讓你的應…

springboot--實戰--大事件--用戶接口開發

開發模式&環境搭建 開發模式&#xff1a; 前后端分離開發 前端程序員寫前端頁面&#xff0c;后端程序員寫后端的接口&#xff0c;前端工程發送請求來訪問后臺&#xff0c;后臺處理完請求后要給前端相應對應的數據。 還需要一套標準來約束即接口文檔&#xff0c;在接口文…

html使用JS實現賬號密碼登錄的簡單案例

目錄 案例需求 思路 錯誤案例及問題 修改思路 案例提供 所需要的組件 <input>標簽&#xff0c;<button>標簽&#xff0c;<script>標簽 詳情使用參考&#xff1a;HTML 教程 | 菜鳥教程 案例需求 編寫一個程序&#xff0c;最多允許用戶嘗試登錄 3 次。…

小米玄戒O1架構深度解析(一):十核異構設計與緩存層次詳解

前言 這兩天&#xff0c;小米的全新SOC玄戒O1橫空出世&#xff0c;引發了科技數碼圈的一次小地震&#xff0c;那么小米的這顆所謂的自研SOC&#xff0c;內部究竟有著什么不為人知的秘密呢&#xff1f;我們一起一探究竟。 目錄 前言1 架構總覽1.1 基本構成1.2 SLC缺席的原因探…

VSCode如何像Pycharm一樣“““回車快速生成函數注釋文檔?如何設置文檔的樣式?autoDocstring如何設置自定義模板?

文章目錄 ?? 介紹 ???? 演示環境 ???? 讓VSCode擁有PyCharm級注釋生成能力 ???? 實現方案??? 備用方案?? 自定義注釋文檔格式樣式 ???? 切換主流注釋風格? 深度自定義模板??? 類型提示與注釋聯動優化?? 相關鏈接 ???? 介紹 ?? 用PyCharm寫P…

數據庫的事務(Transaction)

在數據庫中&#xff0c;事務&#xff08;Transaction&#xff09; 是保證數據操作一致性和完整性的核心機制。它通過一組原子性的操作單元&#xff0c;確保所有操作要么全部成功&#xff08;提交&#xff09;&#xff0c;要么全部失敗&#xff08;回滾&#xff09;。以下是數據…

2025-05-27 Python深度學習7——損失函數和反向傳播

文章目錄 1 損失函數1.1 L1Loss1.2 MSELoss1.3 CrossEntropyLoss 2 反向傳播 本文環境&#xff1a; Pycharm 2025.1Python 3.12.9Pytorch 2.6.0cu124 1 損失函數 ? 損失函數 (loss function) 是將隨機事件或其有關隨機變量的取值映射為非負實數以表示該隨機事件的"風險&…

python+tkinter實現GUI界面調用即夢AI文生圖片API接口

背景 目前字節跳動公司提供了即夢AI的接口免費試用&#xff0c;但是并發量只有1&#xff0c;不過足夠我們使用了。我這里想做個使用pythontkinter實現的GUI可視化界面客戶端&#xff0c;這樣就不用每次都登錄官方網站去進行文生圖片&#xff0c;當然文生視頻&#xff0c;或者圖…

#git 儲藏庫意外被清空 Error: bad index – Fatal: index file corrupt

問題&#xff1a;通常是由于 Git 的索引文件損壞導致 原因&#xff1a;系統崩潰或斷電、硬盤故障、Git 操作錯誤等 方案&#xff1a;重建索引文件&#xff1a;將當前的索引文件重命名為其他名稱或刪除&#xff0c;比如 index.m&#xff0c;然后命令行重建索引&#xff0c;git…

GitLab 18.0 正式發布,15.0 將不再受技術支持,須升級【二】

GitLab 是一個全球知名的一體化 DevOps 平臺&#xff0c;很多人都通過私有化部署 GitLab 來進行源代碼托管。極狐GitLab 是 GitLab 在中國的發行版&#xff0c;專門為中國程序員服務。可以一鍵式部署極狐GitLab。 學習極狐GitLab 的相關資料&#xff1a; 極狐GitLab 官網極狐…

車載網關策略 --- 車載網關通信故障處理機制深度解析

我是穿拖鞋的漢子,魔都中堅持長期主義的汽車電子工程師。 老規矩,分享一段喜歡的文字,避免自己成為高知識低文化的工程師: 鈍感力的“鈍”,不是木訥、遲鈍,而是直面困境的韌勁和耐力,是面對外界噪音的通透淡然。 生活中有兩種人,一種人格外在意別人的眼光;另一種人無論…

Unity數字人開發筆記

開源工程地址&#xff1a;https://github.com/zhangliwei7758/unity-AI-Chat-Toolkit 先致敬zhangliwei7758&#xff0c;開放這個源碼 一、建立工程 建立Unity工程&#xff08;UnityAiChat&#xff09;拖入Unity-AI-Chat-Toolkit.unitypackage打開chatSample工程&#xff0c;可…

Cherry Studio連接配置MCP服務器

之前寫了一篇關于Cherry Studio的文章&#xff0c;不了解的可以先看一下 AI工具——Cherry Studio&#xff0c;搭建滿血DeepSeek R1的AI對話客戶端【硅基流動DeepSeek API】-CSDN博客 最近Cherry Studio更新了一個新功能&#xff1a;MCP服務器 在 v1.2.9 版本中&#xff0c;…

OpenSSH 服務配置與會話保活完全指南

一、/etc/ssh/sshd_config 配置機制 1. 配置文件基礎 文件作用 OpenSSH 服務器 (sshd) 的主配置文件&#xff0c;控制連接、認證、端口轉發等行為。 加載與生效 修改后需重啟服務&#xff1a;sudo systemctl restart sshd # Systemd 系統 sudo service ssh restart # S…

阿里云國際版注冊郵箱格式詳解

“為什么我的阿里云國際版注冊總提示郵箱無效&#xff1f;” 這是許多初次接觸阿里云國際版&#xff08;Alibaba Cloud International&#xff09;的用戶常遇到的困惑。隨著全球化進程加速&#xff0c;越來越多的企業選擇阿里云國際版部署海外業務&#xff0c;而注冊環節中郵箱…

【IDEA問題】springboot本地啟動應用報錯:程序包不存在;找不到符號

問題&#xff1a; springboot本地啟動應用報錯&#xff1a; 程序包xxx不存在&#xff1b;找不到符號 解決方案&#xff1a; 1.確保用maven重新導入依賴 2.刪除.idea文件夾 3.invalidate caches里&#xff0c;把能選擇的都勾選上&#xff0c;然后清除緩存重啟 4.再在上方工具欄…

FFmpeg 時間戳回繞處理:保障流媒體時間連續性的核心機制

FFmpeg 時間戳回繞處理&#xff1a;保障流媒體時間連續性的核心機制 一、回繞處理函數 /** * Wrap a given time stamp, if there is an indication for an overflow * * param st stream // 傳入一個指向AVStream結構體的指針&#xff0c;代表流信息 * pa…

【b站計算機拓荒者】【2025】微信小程序開發教程 - chapter3 項目實踐 -1 項目功能描述

1 項目功能描述 # 智慧社區-小程序-1 歡迎頁-加載后端&#xff1a;動態變化-2 首頁-輪播圖&#xff1a;動態-公共欄&#xff1a;動態-信息采集&#xff0c;社區活動&#xff0c;人臉檢測&#xff0c;語音識別&#xff0c;心率檢測&#xff0c;積分商城-3 信息采集頁面-采集人數…

5.27 day 30

知識點回顧&#xff1a; 導入官方庫的三種手段導入自定義庫/模塊的方式導入庫/模塊的核心邏輯&#xff1a;找到根目錄&#xff08;python解釋器的目錄和終端的目錄不一致&#xff09; 作業&#xff1a;自己新建幾個不同路徑文件嘗試下如何導入 一、導入官方庫 我們復盤下學習py…