Leetcode——151.反轉字符串中的單詞

題解一

思路

最開始的想法是把一個字符串分為字符串數組,但是不知道一共有幾個單詞(當時沒想起來split()),所以選擇了用ArrayList儲存字符串,在輸出時沒有考慮ArrayList可以存儲空字符串,所以最開始的輸出不正確,改進之后正確了。

代碼

class Solution {public String reverseWords(String s) {List<String> list = new ArrayList<>();int tag = 0;for(int i = 0; i < s.length(); i++){if(i == s.length() - 1 && s.charAt(i) != ' '){list.add(s.substring(tag));}if(s.charAt(i) == ' '){list.add(s.substring(tag,i));tag = i + 1;}}String res = "";for(int i = list.size() - 1; i >= 0; i--){if(!list.get(i).isEmpty()) res += list.get(i) +  " ";}res = res.trim();return res;}
}

總結

對字符串還是不夠熟練,有好多方法在用的時候想不起來

題解二?

思路

首先用trim()方法將s前后的空格消掉,然后再用split()函數識別多個連續空格,在一個或多個連續空格處分開,用字符串數組存儲,再用Collections.reverse()進行顛倒,然后再用join()函數用空格做間隔輸出。

代碼

class Solution {public String reverseWords(String s) {String[] str = s.trim().split("\\s+");List<String> list = Arrays.asList(str);Collections.reverse(list);return String.join(" ",list);}
}

總結

用到很多String的內置函數,非常簡潔。

也學習到了很多新知識,比如trim()、split()、asList()、Collections類、\\s+正則表達式。其中trim()和split()就不多說了

asList()

通過asList()得到的列表,不能進行add()和remove()操作,但可以進行set()操作,這也是為什么雖然這個方法也新建了動態數組,但是并沒有增加空間復雜度(是String[]增加了這個方法的空間復雜度)。Arrays.asList() 返回的 List 實際上是一個基于數組的視圖(view),即它并沒有復制數組的內容,而是直接操作原數組的引用。這也是為什么他不能進行add()和remove()操作,因為這里的List是固定大小的,

\\s+

第一次使用正則表達式,用的時候就搞不懂這里為什么是\\雙反斜杠,說說我自己的理解。\n,\t 這種\是轉義符。\\s里的第一個\代表轉義符,告訴Java這里要轉義,而第二個\是正則表達式里的\,和s是一起的,\s表示正則中的空白字符。而\n,\t并不是正則表達式,所以不需要用\\

題解三

思路

首先將整個字符串變成“標準”字符串(即前后無空格,相鄰單詞間只有一個空格),然后將整個字符串倒轉,最后分別將字符串的每個單詞再分別倒轉。

代碼

class Solution {public String reverseWords(String s) {StringBuilder sb = removeSpace(s);reverseString(sb, 0, sb.length()-1);reverseEachWord(sb);return sb.toString();}
//1.除去多余空白符public StringBuilder removeSpace(String s){int start = 0;int end = s.length() - 1;StringBuilder sb = new StringBuilder();while(s.charAt(start) == ' '){start++;}while(s.charAt(end) == ' '){end--;}while(start <= end){if(s.charAt(start) != ' ' || sb.charAt(sb.length() - 1) != ' '){sb.append(s.charAt(start));}start++;}return sb;}
//2.倒轉整個字符串public void reverseString(StringBuilder sb, int start, int end){while(start <= end){char temp = sb.charAt(start);sb.setCharAt(start, sb.charAt(end));sb.setCharAt(end, temp);start++;end--;}}
//3.分別倒轉字符串中的每個單詞public void reverseEachWord(StringBuilder sb){int start = 0;int end = 1;int length = sb.length();while(start < length){while(end < length && sb.charAt(end) != ' '){end++;}reverseString(sb, start, end - 1);start = end + 1;end = start + 1;}}
}

總結

最后這種題解,只需新建一個新的StringBuilder類型對象,然后在該StringBuilder進行修改,不需要額外開辟數組或集合,空間復雜度低。

就是太復雜了!!學習過后復現都很難!!!

番外:

今天用了StringBuilder,昨天使用了StringBuffer,二者的區別是StringBuffer的方法使用synchronized修飾,具有線程安全的特點,但是相應的響應速度就更慢一些,看在哪里使用

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

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

相關文章

Oracle檢索數據

一、Oracle用戶模式與模式 對象 1.概念 模式就是數據庫對象的集合&#xff0c;數據庫對象包括表、函數、索引、視圖、過程。 2.示例模式scott SQL> select table_name from user_tables;TABLE_NAME ------------------------------------------------------------------…

Java學習------static、final、this、super關鍵字

1. static關鍵字 static修飾的變量叫做靜態變量。當所有對象的某個屬性的值是相同的&#xff0c;建議將該屬性定義為靜態變量&#xff0c;來節省內存的開銷。靜態變量在類加載時初始化&#xff0c;存儲在堆中。static修飾的方法叫做靜態方法。所有靜態變量和靜態方法&#xff…

一個簡單的 **猜數字游戲** 的 C 語言例程

一個簡單的 猜數字游戲 的 C 語言例程&#xff0c;代碼包含詳細注釋&#xff0c;適合學習和練習基礎語法&#xff1a; #include <stdio.h> #include <stdlib.h> #include <time.h> // 用于生成隨機數種子int main() {int target, guess, attempts 0;srand…

Keepalived 多主模型與 LVS 高可用

一.Keepalived多主模型 Keepalived多主模型概念 如上圖&#xff0c;keepalived主從架構性能損耗較嚴重&#xff0c;如果業務分類明確&#xff0c;則可以配置keepalived多主模型降低損耗&#xff0c;兩臺keepalived互為主備&#xff0c;如&#xff1a;訂單業務走keepalived1&am…

RISCV虛擬化環境搭建

概要 本文記搭建 RISCV 虛擬化環境的流程。 整體架構 我們使用 QEMU 來模擬 RISCV 的各種硬件擴展環境&#xff0c;通過 QEMU 啟動 Ubuntu 作為我們的 Host 來在 Host 之中通過 KVMTOOL 來運行 Guest&#xff0c;學習 RISCV 的虛擬化。 目前我的 X86_64 主機使用的是 Ubunt…

書摘 ASP.NET Core技術內幕與項目實戰:基于DDD與前后端分離

IT行業的發展瞬息萬變,新技術層出不窮,很多技術人員出于個人興趣、個人職業發展等考慮而選擇一些流行的新技術,他們會把各種復雜的架構模式、高精尖的技術都加入架構中,這增加了項目的復雜度、延長了交付周期、增加了項目的研發成本。有些技術并不符合公司的情況,最后項目…

神策數據接入 DeepSeek,AI 賦能數據分析與智能運營

在 AI 技術迅猛發展的浪潮下&#xff0c;神策數據正在加速推進人工智能在數據分析和智能運營領域的深度應用。近日&#xff0c;神策數據宣布全面接入 DeepSeek&#xff0c;為企業客戶帶來更加智能化、高效的數據分析與智能運營服務。這一舉措展現了神策數據在人工智能方向的探索…

c++ 類和對象 —— 中 【復習筆記】

1. 類的默認成員函數 如果一個類什么成員都沒有&#xff0c;簡稱空類。但實際上&#xff0c;任何類在不寫成員時&#xff0c;編譯器會自動生成6個默認成員函數&#xff08;用戶未顯式實現&#xff0c;編譯器生成的成員函數&#xff09; 這6個成員函數可分為三類&#xff1a; …

數學建模:MATLAB循環神經網絡

一、簡述 1.循環神經網絡 循環神經網絡&#xff08;RNN&#xff09;是一種用于處理序列數據的神經網絡。不同于傳統的前饋神經網絡&#xff0c;RNN在隱藏層中加入了自反饋連接&#xff0c;使得網絡能夠對序列中的每個元素執行相同的操作&#xff0c;同時保持一個“記憶”狀態…

在windows10系統上安裝docker,然后在容器中運行GPU版本的Pytorch,并使用vscode連接該容器

一 . 安裝Docker Desktop 首先打開網址https://docs.docker.com/desktop/install/windows-install/ 下載完后&#xff0c;雙擊下面的exe文件進行安裝&#xff0c;默認情況下&#xff0c;Docker Desktop 安裝在C:\Program Files\Docker\Docker 出現提示時&#xff0c;請確保…

基于SpringBoot + Vue 的房屋租賃系統

基于springboot的房屋租賃管理系統-帶萬字文檔 SpringBootVue房屋租賃管理系統 送文檔 本項目有前臺和后臺兩部分、多角色模塊、不同角色權限不一樣 共分三種角色&#xff1a;用戶、管理員、房東 管理員&#xff1a;個人中心、房屋類型管理、房屋信息管理、預約看房管理、合…

C++特性——智能指針

為什么需要智能指針 對于定義的局部變量&#xff0c;當作用域結束之后&#xff0c;就會自動回收&#xff0c;這沒有什么問題。 當時用new delete的時候&#xff0c;就是動態分配對象的時候&#xff0c;如果new了一個變量&#xff0c;但卻沒有delete&#xff0c;這會造成內存泄…

C語言之 循環語句:程序運行的核心動力(上)

個人主頁&#xff1a;strive-debug 在 C 語言中&#xff0c;分支結構可以通過 if、switch 語句來實現&#xff0c;循環結構則可以通過 for、while、do while 語句來實現。 if 語句 if 語句的語法形式如下&#xff1a; if (表達式)語句; 如果表達式成立&#xff08;為真&am…

FreeRTOSBug解析:一個任務printf打印一半突然跳轉另一個任務,導致另一個任務無法打印

bug現象&#xff1a; key任務&#xff1a; 默認任務&#xff1a; 此時兩個任務的優先級相同&#xff0c;搶占式調度&#xff0c;時間片輪轉&#xff0c;空閑任務讓步。 但是會出現一個問題&#xff0c;key任務在發送完隊列之后不會立即跳轉到默認任務的隊列接收函數后的print…

操作系統八股文整理(一)

操作系統八股文整理 一、進程和線程的區別二、進程與線程的切換過程一、進程切換進程切換的步驟&#xff1a; 二、線程切換線程切換的步驟&#xff1a; 三、進程切換與線程切換的對比四、上下文切換的優化 三、系統調用一、系統調用的觸發二、從用戶空間切換到內核空間三、執行…

卷積神經網絡(CNN)之 EfficientNet

在深度學習領域&#xff0c;模型的計算效率與性能之間的平衡一直是一個核心挑戰。隨著卷積神經網絡&#xff08;CNN&#xff09;在圖像分類、目標檢測等任務中取得顯著成果&#xff0c;模型的復雜度和計算需求也急劇增加。2019年&#xff0c;Google Research 提出的 EfficientN…

學生選課管理系統數據庫設計報告

學生選課管理系統數據庫設計報告 一、需求分析 &#xff08;一&#xff09;項目背景 學生選課管理系統是高校教學管理的重要組成部分&#xff0c;旨在實現學生選課、課程管理、成績錄入與查詢等功能的自動化和信息化。通過該系統&#xff0c;學生可以方便地選擇課程&#xf…

工具介紹《Awsome-Redis-Rogue-Server 與 redis-rogue-server》

1. 核心功能與攻擊場景 redis-rogue-server 基于Redis主從復制漏洞&#xff08;CVE未公開&#xff09;&#xff0c;針對Redis 4.x~5.0.5版本設計&#xff0c;通過偽造惡意主節點強制同步惡意模塊&#xff08;.so文件&#xff09;實現遠程代碼執行&#xff08;RCE&#xff09;。…

Razor C# 變量

Razor C# 變量 引言 在ASP.NET MVC和Razor視圖引擎中,變量是構建動態網頁的基礎。理解Razor C#變量的使用對于開發者來說至關重要。本文將詳細介紹Razor C#變量的概念、類型、作用域以及如何在實際項目中有效使用它們。 一、Razor C# 變量的概念 Razor C# 變量是存儲在Raz…

【QA】模板方法模式在Qt中有哪些應用?

在 Qt 框架中&#xff0c;模板方法模式&#xff08;Template Method Pattern&#xff09;被廣泛應用于框架的設計中&#xff0c;通過定義算法骨架并允許子類在不改變結構的情況下重寫部分步驟。以下是 Qt 中典型的應用場景及示例&#xff1a; 1. 事件處理&#xff08;Event Ha…