向字符串添加空格

給你一個下標從?0?開始的字符串?s?,以及一個下標從?0?開始的整數數組?spaces?。

數組?spaces?描述原字符串中需要添加空格的下標。每個空格都應該插入到給定索引處的字符值?之前?。

  • 例如,s = "EnjoyYourCoffee"?且?spaces = [5, 9]?,那么我們需要在?'Y'?和?'C'?之前添加空格,這兩個字符分別位于下標?5?和下標?9?。因此,最終得到?"Enjoy Your Coffee"?。

請你添加空格,并返回修改后的字符串

class Solution {public String addSpaces(String s, int[] spaces) {StringBuilder ans=new StringBuilder(s.length()+spaces.length);int j=0;for(int i=0;i<s.length();i++){if(j<spaces.length&&spaces[j]==i){ans.append(' ');j++;}ans.append(s.charAt(i));}return ans.toString();}
}

如果輸入s="nicetomeetyou".spaces[4,6,10]

  • 當?i = 0?時,j = 0?,spaces[0] = 4?,不滿足?spaces[j] == i?,執行?ans.append(s.charAt(0))?,此時?ans?為?"n"?。
  • 當?i = 1?時,同理,執行?ans.append(s.charAt(1))?,ans?變為?"ni"?。
  • 當?i = 2?時,執行?ans.append(s.charAt(2))?,ans?變為?"nic"?。
  • 當?i = 3?時,執行?ans.append(s.charAt(3))?,ans?變為?"nice"?。
  • 當?i = 4?時,j = 0?,spaces[0] = 4?,滿足?j < spaces.length && spaces[j] == i?,先執行?ans.append(' ')?,此時?ans?為?"nice "?,然后?j++?,j?變為?1?,再執行?ans.append(s.charAt(4))?,ans?變為?"nice t"?。
  • 當?i = 5?時,不滿足?spaces[j] == i?(此時?spaces[1] = 6?),執行?ans.append(s.charAt(5))?,ans?變為?"nice to"?。
  • 當?i = 6?時,滿足?j < spaces.length && spaces[j] == i?(此時?j = 1?,spaces[1] = 6?),先執行?ans.append(' ')?,ans?變為?"nice to "?,然后?j++?,j?變為?2?,再執行?ans.append(s.charAt(6))?,ans?變為?"nice to m"?。
  • 后續以此類推,繼續遍歷字符串?s?,當?i = 10?時,滿足條件,添加空格。

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

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

相關文章

百人會上的蔚小理與「來的剛剛好」的雷軍

這就是2025百人會上的蔚小理&#xff0c;努力的李斌、宣揚飛行汽車的何小鵬與大講開源的李想。那么小米汽車的模式是什么呢&#xff1f;站在蔚小理的肩上。 這就是2025百人會上的蔚小理&#xff0c;努力的李斌、宣揚飛行汽車的何小鵬與大講開源的李想。那么小米汽車的模式是什么…

解鎖Nginx路由器匹配規則

引言 Nginx 無疑是一款備受矚目的明星產品。它以其高性能、高可靠性以及出色的并發處理能力&#xff0c;在眾多 Web 服務器和反向代理服務器中脫穎而出 &#xff0c;廣泛應用于各類網站和應用程序中。據統計&#xff0c;超過 30% 的網站都在使用 Nginx 作為其 Web 服務器&…

傳統策略梯度方法的弊端與PPO的改進:穩定性與樣本效率的提升

為什么傳統策略梯度方法&#xff08;如REINFORCE算法&#xff09;在訓練過程中存在不穩定性和樣本效率低下的問題 1. 傳統策略梯度方法的基本公式 傳統策略梯度方法的目標是最大化累積獎勵的期望值。具體來說&#xff0c;優化目標可以表示為&#xff1a; max ? θ J ( θ )…

Qwt入門

Qwt(Qt Widgets for Technical Applications)是一個用于科學、工程和技術應用的 Qt 控件庫,提供曲線圖、儀表盤、刻度尺等專業可視化組件。 1. 安裝與配置 1.1 安裝方式 源碼編譯(推薦): git clone https://github.com/qwt/qwt.git cd qwt qmake qwt.pro # 生成 Makef…

軟考《信息系統運行管理員》- 6.1 信息系統安全概述

信息系統安全的概念 信息系統安全是指保障計算機及其相關設備、設施(含網絡)的安全&#xff0c;運行環境的安全&#xff0c; 信息的安全&#xff0c;實現信息系統的正常運行。 信息系統安全包括實體安全、運行安全、信息安全和 人員安全等幾個部分。 影響信息系統安全的因素…

Canvas實現旋轉太極八卦圖

Canvas實現旋轉太極八卦圖 項目簡介 這是一個使用HTML5 Canvas技術實現的動態太極八卦圖&#xff0c;包含了旋轉動畫和鼠標交互功能。項目展示了中國傳統文化元素與現代Web技術的結合。 主要特點 動態旋轉的太極圖八卦符號的完整展示鼠標懸停暫停動畫流暢的動畫效果 技術實…

機器學習、深度學習和神經網絡

機器學習、深度學習和神經網絡 術語及相關概念 在深入了解人工智能&#xff08;AI&#xff09;的工作原理以及它的各種應用之前&#xff0c;讓我們先區分一下與AI密切相關的一些術語和概念&#xff1a;人工智能、機器學習、深度學習和神經網絡。這些術語有時會被交替使用&#…

打造高性能中文RAG系統:多輪對話與語義檢索的完美結合

目錄 1、引言 2、RAG系統的核心架構 3、對話理解&#xff1a;超越單輪問答 3.1、指代消解技術 3.2、話題跟蹤與記憶 4、混合檢索策略&#xff1a;兼顧精確與廣泛 4.1、向量檢索 關鍵詞檢索 4.2、重排序機制 5、性能優化&#xff1a;應對大規模文檔 5.1、向量量化技術…

人工智能助力數字化轉型:生成式人工智能(GAI)認證開啟新篇章

在數字化浪潮席卷全球的今天&#xff0c;企業正面臨著前所未有的轉型壓力與機遇。數字化轉型&#xff0c;這一曾經被視為“選擇題”的戰略議題&#xff0c;如今已演變為關乎企業生存與發展的“必答題”。在這場深刻的變革中&#xff0c;人工智能&#xff08;AI&#xff09;作為…

Windows 圖形顯示驅動開發-WDDM 2.4功能-GPU 半虛擬化(十二)

DxgkDdiQueryAdapterInfo 更新 DXGKARG_QUERYADAPTERINFO 結構已更新&#xff0c;以包括以下字段以支持半虛擬化&#xff1a; 添加了 Flags 成員&#xff0c;允許 Dxgkrnl 指示以下內容&#xff1a; 它將 VirtualMachineData 設置為指示調用來自 VM。它將 SecureVirtualMach…

iOS審核被拒:Missing privacy manifest 第三方庫添加隱私聲明文件

問題&#xff1a; iOS提交APP審核被拒&#xff0c;蘋果開發者網頁顯示二進制錯誤&#xff0c;收到的郵件顯示的詳細信息如下圖: 分析&#xff1a; 從上面信息能看出第三方SDK庫必須要包含一個隱私文件&#xff0c;去第三方庫更新版本。 幾經查詢資料得知&#xff0c;蘋果在…

馬達加斯加企鵝字幕

Antarctica 南極洲 An inhospitable wasteland 一個荒涼的不毛之地 But even here 但即使在這里 on the Earth’s frozen bottom 地球另一端的冰天雪地里 we find life 也有生命存在 And not just any life 不是別的什么生物 Penguins 而是企鵝 Joyous, frolicking 快樂的 頑皮…

愛因斯坦求和 torch

目錄 向量點積 矩陣乘法 矩陣轉置 向量轉換相機坐標系 在 Python 的科學計算庫&#xff08;如 NumPy&#xff09;中&#xff0c;einsum 是一個強大的函數&#xff0c;它可以簡潔地表示各種張量運算。下面是幾個不同類型的使用示例&#xff1a; 向量點積 向量點積是兩個向量…

FPGA調試筆記

XILINX SSTL屬性電平報錯 錯誤如下&#xff1a; [DRC BIVRU-1] Bank IO standard Vref utilization: Bank 33 contains ports that use a reference voltage. In order to use such standards in a bank that is not configured to use INTERNAL_VREF, the banks VREF pin mu…

一區嚴選!挑戰5天一篇脂質體組學 DAY1-5

Day 1! 前期已經成功挑戰了很多期NHANES啦&#xff01;打算來試試孟德爾隨機化領域&#xff5e; 隨著孟德爾隨機化研究的普及&#xff0c;現在孟德爾發文的難度越來越高&#xff0c;簡單的雙樣本想被接收更是難上加難&#xff0c;那么如何破除這個困境&#xff0c;這次我打算…

DataGear 5.3.0 制作支持導出表格數據的數據可視化看板

DataGear 內置表格圖表底層采用的是DataTable表格組件&#xff0c;默認并未引入導出數據的JS支持庫&#xff0c;如果有導出表格數據需求&#xff0c;則可以在看板中引入導出相關JS支持庫&#xff0c;制作具有導出CSV、Excel、PDF功能的表格數據看板。 在新發布的5.3.0版本中&a…

【個人筆記】用戶注冊登錄思路及實現 springboot+mybatis+redis

基本思路 獲取驗證碼接口 驗證碼操作用了com.pig4cloud.plugin的captcha-core這個庫。 AccountControl的"/checkCode"接口代碼&#xff0c;通過ArithmeticCaptcha生成一張驗證碼圖片&#xff0c;通過text()函數得到驗證碼的答案保存到變量code&#xff0c;然后把圖…

Linux網絡編程概述

Linux網絡編程是在Linux操作系統環境下進行的網絡相關程序開發&#xff0c;主要用于實現不同計算機之間的數據通信和資源共享。以下從基礎知識、網絡編程模型、常用函數和編程步驟等方面進行詳細介紹&#xff1a; 基礎知識 1. 網絡協議 TCP/IP協議族&#xff1a;是互聯網通信…

Linux內核perf性能分析工具案例分析

一、系統級性能分析工具perf原理 1. perf 的基本概念 內核集成&#xff1a;perf 直接集成在 Linux 內核源碼中&#xff0c;能夠深度訪問硬件和操作系統層面的性能數據&#xff0c;具有低開銷、高精度的特點。 事件采樣原理&#xff1a;通過定期采樣系統事件&#xff0…

word-spacing 屬性

介紹 CSS word-spacing 屬性&#xff0c;用于指定段字之間的空間&#xff0c;例如&#xff1a; p {word-spacing:30px; }word-spacing屬性增加或減少字與字之間的空白。 注意&#xff1a; 負值是允許的。 瀏覽器支持 表格中的數字表示支持該屬性的第一個瀏覽器版本號。 屬…