3163。字符串壓縮 III
難度:中等
主題:字符串
給定一個(gè)字符串單詞,使用以下算法對(duì)其進(jìn)行壓縮:
- 以空字符串 comp 開始。當(dāng)單詞不是為空時(shí),使用以下操作:
- 刪除由單個(gè)字符 c 組成的單詞的最大長(zhǎng)度前綴,重復(fù)最多 9 次。
- 將 c 后面的前綴長(zhǎng)度附加到 comp。
返回字符串comp.
示例1:
- 輸入: word = "abcde"
- 輸出:“1a1b1c1d1e”
-
解釋: 最初,comp = ""。應(yīng)用該操作 5 次,每次操作選擇“a”、“b”、“c”、“d”和“e”作為前綴。
- 對(duì)于每個(gè)前綴,附加“1”,后跟要組成的字符。
示例2:
- 輸入: word = "aaaaaaaaaaaaaabb"
- 輸出:“9a5a2b”
-
解釋: 最初,comp = ""。應(yīng)用該操作 3 次,每次操作選擇“aaaaaaaaa”、“aaaaa”和“bb”作為前綴。
- 對(duì)于前綴“aaaaaaaaa”,請(qǐng)?jiān)?comp 后附加“9”,后跟“a”。
- 對(duì)于前綴“aaaaa”,請(qǐng)?jiān)?comp 后附加“5”,后跟“a”。
- 對(duì)于前綴“bb”,將“2”后跟“b”添加到 comp。
約束:
- 1 5
- 單詞僅由小寫英文字母組成。
提示:
- 每次最多只剪切前綴中的相同字符 9 次。削減更大的前綴總是更好。
解決方案:
我們可以使用貪心方法來壓縮字符串,方法是獲取重復(fù)字符的最長(zhǎng)可能前綴(一次最多出現(xiàn) 9 次),然后將前綴的長(zhǎng)度與字符一起附加到結(jié)果中。
以下是分步解決方案:
-
初始化變量:
- comp(壓縮字符串)以空字符串開頭。
- 使用指針或索引 i 來跟蹤單詞中的位置。
-
循環(huán)單詞:
- 趁word中剩余字符,找到不超過9個(gè)字符的最長(zhǎng)重復(fù)字符前綴。
- 計(jì)算當(dāng)前字符連續(xù)重復(fù)的次數(shù),最多 9 次。
-
附加到壓縮字符串:
- 將計(jì)數(shù)后面的字符添加到 comp。
- 將指針 i 向前移動(dòng)已處理的字符數(shù)。
-
返回結(jié)果:
- 處理整個(gè)字符串后,返回壓縮后的字符串comp。
讓我們用 PHP 實(shí)現(xiàn)這個(gè)解決方案:3163。字符串壓縮 III
<?php /** * @param String $word * @return String */ function compressString($word) { ... ... ... /** * go to ./solution.php */ } // Test cases echo compressString("abcde"); // Output: "1a1b1c1d1e" echo "\n"; echo compressString("aaaaaaaaaaaaaabb"); // Output: "9a5a2b" ?>
解釋:
- 計(jì)數(shù)循環(huán):我們?cè)谥餮h(huán)內(nèi)使用 while 循環(huán)來計(jì)算單詞中每個(gè)唯一字符的連續(xù)字符(最多 9 個(gè))。
- 附加結(jié)果:對(duì)每個(gè)序列進(jìn)行計(jì)數(shù)后,我們將計(jì)數(shù)和字符直接附加到 comp。
- 指針更新:主循環(huán)指針i向前移動(dòng)所統(tǒng)計(jì)的字符數(shù),有效減少每次迭代中剩余字符串的大小。
復(fù)雜性分析
- 時(shí)間復(fù)雜度:O(n),其中n是單詞的長(zhǎng)度。每個(gè)字符都會(huì)被處理一次。
- 空間復(fù)雜度:O(n) 存儲(chǔ)在comp. 中的壓縮結(jié)果
此解決方案非常高效,可以處理邊緣情況,例如短于 9 個(gè)字符的序列或每個(gè)字符僅出現(xiàn)一次。
聯(lián)系鏈接
如果您發(fā)現(xiàn)本系列有幫助,請(qǐng)考慮在 GitHub 上給 存儲(chǔ)庫(kù) 一個(gè)星號(hào)或在您最喜歡的社交網(wǎng)絡(luò)上分享該帖子?。您的支持對(duì)我來說意義重大!
如果您想要更多類似的有用內(nèi)容,請(qǐng)隨時(shí)關(guān)注我:
- 領(lǐng)英
- GitHub
以上是字符串壓縮 III的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

熱AI工具

Undress AI Tool
免費(fèi)脫衣服圖片

Undresser.AI Undress
人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover
用于從照片中去除衣服的在線人工智能工具。

Clothoff.io
AI脫衣機(jī)

Video Face Swap
使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費(fèi)的代碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
功能強(qiáng)大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6
視覺化網(wǎng)頁(yè)開發(fā)工具

SublimeText3 Mac版
神級(jí)代碼編輯軟件(SublimeText3)

PHP變量作用域常見問題及解決方法包括:1.函數(shù)內(nèi)部無法訪問全局變量,需使用global關(guān)鍵字或參數(shù)傳入;2.靜態(tài)變量用static聲明,只初始化一次并在多次調(diào)用間保持值;3.超全局變量如$_GET、$_POST可在任何作用域直接使用,但需注意安全過濾;4.匿名函數(shù)需通過use關(guān)鍵字引入父作用域變量,修改外部變量則需傳遞引用。掌握這些規(guī)則有助于避免錯(cuò)誤并提升代碼穩(wěn)定性。

要安全處理PHP文件上傳需驗(yàn)證來源與類型、控制文件名與路徑、設(shè)置服務(wù)器限制并二次處理媒體文件。1.驗(yàn)證上傳來源通過token防止CSRF并通過finfo_file檢測(cè)真實(shí)MIME類型使用白名單控制;2.重命名文件為隨機(jī)字符串并根據(jù)檢測(cè)類型決定擴(kuò)展名存儲(chǔ)至非Web目錄;3.PHP配置限制上傳大小及臨時(shí)目錄Nginx/Apache禁止訪問上傳目錄;4.GD庫(kù)重新保存圖片清除潛在惡意數(shù)據(jù)。

PHP注釋代碼常用方法有三種:1.單行注釋用//或#屏蔽一行代碼,推薦使用//;2.多行注釋用/.../包裹代碼塊,不可嵌套但可跨行;3.組合技巧注釋如用/if(){}/控制邏輯塊,或配合編輯器快捷鍵提升效率,使用時(shí)需注意閉合符號(hào)和避免嵌套。

AgeneratorinPHPisamemory-efficientwaytoiterateoverlargedatasetsbyyieldingvaluesoneatatimeinsteadofreturningthemallatonce.1.Generatorsusetheyieldkeywordtoproducevaluesondemand,reducingmemoryusage.2.Theyareusefulforhandlingbigloops,readinglargefiles,or

寫好PHP注釋的關(guān)鍵在于明確目的與規(guī)范,注釋應(yīng)解釋“為什么”而非“做了什么”,避免冗余或過于簡(jiǎn)單。1.使用統(tǒng)一格式,如docblock(/*/)用于類、方法說明,提升可讀性與工具兼容性;2.強(qiáng)調(diào)邏輯背后的原因,如說明為何需手動(dòng)輸出JS跳轉(zhuǎn);3.在復(fù)雜代碼前添加總覽性說明,分步驟描述流程,幫助理解整體思路;4.合理使用TODO和FIXME標(biāo)記待辦事項(xiàng)與問題,便于后續(xù)追蹤與協(xié)作。好的注釋能降低溝通成本,提升代碼維護(hù)效率。

ToinstallPHPquickly,useXAMPPonWindowsorHomebrewonmacOS.1.OnWindows,downloadandinstallXAMPP,selectcomponents,startApache,andplacefilesinhtdocs.2.Alternatively,manuallyinstallPHPfromphp.netandsetupaserverlikeApache.3.OnmacOS,installHomebrew,thenrun'bre

在PHP中獲取字符串特定索引字符可用方括號(hào)或花括號(hào),但推薦方括號(hào);索引從0開始,超出范圍訪問返回空值,不可賦值;處理多字節(jié)字符需用mb_substr。例如:$str="hello";echo$str[0];輸出h;而中文等字符需用mb_substr($str,1,1)獲取正確結(jié)果;實(shí)際應(yīng)用中循環(huán)訪問前應(yīng)檢查字符串長(zhǎng)度,動(dòng)態(tài)字符串需驗(yàn)證有效性,多語(yǔ)言項(xiàng)目建議統(tǒng)一使用多字節(jié)安全函數(shù)。

易于效率,啟動(dòng)啟動(dòng)tingupalocalserverenverenvirestoolslikexamppandacodeeditorlikevscode.1)installxamppforapache,mysql,andphp.2)uscodeeditorforsyntaxssupport.3)
