亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

首頁(yè) 後端開發(fā) php教程 從左、右各取K個(gè)字符

從左、右各取K個(gè)字符

Nov 24, 2024 pm 08:44 PM

Take K of Each Character From Left and Right

2516。從左右各取K個(gè)字元

難度:

主題:雜湊表、字串、滑動(dòng)視窗

給定一個(gè)由字元 'a'、'b' 和 'c' 組成的字串 s 以及一個(gè)非負(fù)整數(shù) k。每分鐘,您可以選取 s 的最左邊字符,或 s 的最右邊字符。

傳回最少取得至少 k 個(gè)字元所需的分鐘數(shù),如果不可能取得每個(gè)字元的k 個(gè),則傳回-1角色 。

範(fàn)例1:

  • 輸入: s = "aabaaaacaabc", k = 2
  • 輸出: 8
  • 解釋:從 s 左邊取三個(gè)字元。您現(xiàn)在有兩個(gè)“a”字元和一個(gè)“b”字元。
    • 從 s 右側(cè)取五個(gè)字元。您現(xiàn)在有四個(gè)“a”字元、兩個(gè)“b”字元和兩個(gè)“c”字元。
    • 總共需要3 5 = 8分鐘。
    • 可以證明8是最少需要的分鐘數(shù)。

範(fàn)例2:

  • 輸入: s = "a", k = 1
  • 輸出: -1
  • 解釋: 不可能取 'b' 或 'c',因此回傳 -1。

約束:

  • 1 5
  • s 僅由字母 'a'、'b' 和 'c' 組成。
  • 0

提示:

  1. 先計(jì)算每個(gè)字元的出現(xiàn)頻率並檢查是否可能。
  2. 如果從左側(cè)取x個(gè)字符,那麼從右側(cè)最少需要取多少個(gè)字符?對(duì) 0 ≤ x ≤ s.length 範(fàn)圍內(nèi)的所有 x 值求此值。
  3. 使用兩指標(biāo)方法來避免多次計(jì)算相同的資訊。

解:

我們可以使用帶有兩個(gè)指標(biāo)的滑動(dòng)視窗技術(shù)來找到從左側(cè)和右側(cè)取出至少 k 個(gè)字元('a','b','c')所需的最小分鐘數(shù)字串。

問題分解:

  • 給定一個(gè)只包含 'a'、'b' 和 'c' 的字串 s。
  • 我們需要從字串的最左邊或最右邊的字元中取得每個(gè)字元至少出現(xiàn)的 k 次。
  • 我們需要確定實(shí)現(xiàn)此目標(biāo)所需的最小分鐘數(shù),如果不可能,則傳回 -1。

方法:

  1. 初步檢查

    • 如果 k == 0,我們可以直接回傳 0,因?yàn)椴恍枰魏巫衷?
    • 如果 k 超過字串中任意字元出現(xiàn)的次數(shù),則立即傳回 -1。
  2. 頻率計(jì)數(shù):

    • 我們需要統(tǒng)計(jì) 'a'、'b' 和 'c' 在字串 s 中出現(xiàn)了多少次,以確保甚至可以收集到每個(gè)字元的 k 個(gè)。
  3. 滑動(dòng)視窗技術(shù):

    • 使用兩個(gè)指標(biāo)(左和右)的滑動(dòng)視窗方法。
    • 維護(hù)兩個(gè)指針,並從字串兩端滑動(dòng)它們以收集所需的字元。
    • 對(duì)於從左側(cè)取出的每個(gè)字符,計(jì)算需要從右側(cè)取出的最少字符數(shù)才能滿足要求。
  4. 最佳化

    • 我們可以在擴(kuò)展或收縮視窗時(shí)追蹤字元計(jì)數(shù),而不是重複地重新計(jì)算每個(gè)視窗的字元計(jì)數(shù)。

讓我們用 PHP 實(shí)作這個(gè)解:2516。從左右各取K個(gè)

<?php
/**
 * @param String $s
 * @param Integer $k
 * @return Integer
 */
function takeCharacters($s, $k) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Example 1
echo takeCharacters("aabaaaacaabc", 2);  // Output: 8

// Example 2
echo takeCharacters("a", 1);  // Output: -1
?>

解釋:

  1. 初始設(shè)定

    • 我們計(jì)算整個(gè)字串中「a」、「b」和「c」的出現(xiàn)次數(shù),以確??梢允占辽?k 個(gè)字元。
    • 如果任意字元數(shù)小於 k,則傳回 -1。
  2. 滑動(dòng)視窗:

    • 我們使用兩個(gè)指標(biāo)(左和右)從兩端建立一個(gè)滑動(dòng)視窗。
    • 我們透過移動(dòng)右側(cè)指標(biāo)來擴(kuò)展視窗並增加遇到的字元數(shù)。
    • 一旦目前視窗中的每個(gè)字元至少有 k 個(gè),我們就會(huì)嘗試從左側(cè)縮小視窗以最小化分鐘數(shù)(佔(zhàn)用的字元)。
  3. 最小化時(shí)間

    • 每次收集所有類型的 k 個(gè)字元時(shí),我們都會(huì)透過比較視窗的大小來追蹤所需的最少分鐘數(shù)。

時(shí)間複雜度:

  • 計(jì)算字元最初需要 O(n)。
  • 滑動(dòng)視窗操作需要 O(n),因?yàn)樽笥抑笜?biāo)都在字串上移動(dòng)一次。
  • 整體時(shí)間複雜度為 O(n)。

邊緣情況:

  • 如果 k == 0,則回傳 0。
  • 如果不可能取出每個(gè)字元的 k,則傳回 -1。

聯(lián)絡(luò)連結(jié)

如果您發(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

以上是從左、右各取K個(gè)字符的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

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

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
PHP變量範(fàn)圍解釋了 PHP變量範(fàn)圍解釋了 Jul 17, 2025 am 04:16 AM

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

如何在PHP中牢固地處理文件上傳? 如何在PHP中牢固地處理文件上傳? Jul 08, 2025 am 02:37 AM

要安全處理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中評(píng)論代碼 在PHP中評(píng)論代碼 Jul 18, 2025 am 04:57 AM

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

發(fā)電機(jī)如何在PHP中工作? 發(fā)電機(jī)如何在PHP中工作? Jul 11, 2025 am 03:12 AM

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

撰寫PHP評(píng)論的提示 撰寫PHP評(píng)論的提示 Jul 18, 2025 am 04:51 AM

寫好PHP註釋的關(guān)鍵在於明確目的與規(guī)範(fàn),註釋應(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ù)效率。

快速PHP安裝教程 快速PHP安裝教程 Jul 18, 2025 am 04:52 AM

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

如何通過php中的索引訪問字符串中的字符 如何通過php中的索引訪問字符串中的字符 Jul 12, 2025 am 03:15 AM

在PHP中獲取字符串特定索引字符可用方括號(hào)或花括號(hào),但推薦方括號(hào);索引從0開始,超出範(fàn)圍訪問返回空值,不可賦值;處理多字節(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ù)。

學(xué)習(xí)PHP:初學(xué)者指南 學(xué)習(xí)PHP:初學(xué)者指南 Jul 18, 2025 am 04:54 AM

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

See all articles