搜尋
首頁後端開發php教程運算後字串的最小長度
運算後字串的最小長度Jan 13, 2025 pm 10:30 PM

Minimum Length of String After Operations

3223。運算後字串的最小長度

難度:

主題: 雜湊表、字串、計數

給你一個字串 s。

您可以對任意次執行以下程序:

  • 在字串中選擇一個索引i,使得索引i 左側至少有 一個字元等於s[i],並且至少 一個字元右邊也等於s[i].
  • 刪除索引 i 的
  • 左邊 等於 s[i] 的 最接近的 字元。
  • 刪除索引 i 的
  • 右邊 等於 s[i] 的 最接近的 字元。
傳回

可以達到的最終字串s的最小長度

範例1:

  • 輸入: s = "abaacbcbb"
  • 輸出: 5
  • 說明:我們執行以下操作:
      選擇索引 2,然後刪除索引 0 和 3 處的字元。產生的字串為 s = "bacbcbb"。
    • 選擇索引 3,然後刪除索引 0 和 5 處的字元。產生的字串為 s = "acbcb"。

範例2:

  • 輸入: s = "aa"
  • 輸出: 2
  • 解釋:我們無法執行任何操作,因此我們傳回原始字串的長度。

約束:

    1 5 s 僅由小寫英文字母組成。

提示:

    只有每個字元出現的頻率對於找到最終答案很重要。
  1. 如果某個字元出現次數少於 3 次,我們無法對其執行任何處理。
  2. 假設有一個字符在字串中出現至少3次,我們可以重複刪除其中兩個字符,直到最多出現2次。

解:

我們需要注意字串中每個字元的出現頻率。解決方法如下:

方法:

  1. 計算字元頻率:

      使用頻率表來統計每個字元在字串中出現的次數。
  2. 減少頻率>= 3的字元:

      如果一個字元出現3次或以上,我們可以重複刪除其中兩個,直到只剩下2次。
  3. 計算最小長度:

    • 減少頻率後,將所有字元的剩餘數量相加。

讓我們用 PHP 實作這個解:3223。運算後字串的最小長度

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

// Example 1
$s1 = "abaacbcbb";
echo "Input: $s1\n";
echo "Output: " . minimumLength($s1) . "\n";

// Example 2
$s2 = "aa";
echo "Input: $s2\n";
echo "Output: " . minimumLength($s2) . "\n";
?>

解釋:

  1. 頻率計數:

    • 迭代字串,並為每個字元增加 $Frequency 陣列中的計數。
  2. 減少字元:

    • 對於 $Frequency 數組中的每個字符,檢查其計數是否為 3 或更多。如果是這樣,請將其減少到最多 2。
  3. 計算結果:

    • 對 $Frequency 陣列中的值求和以獲得字串的最小可能長度。

演練範例:

範例1:

  • 輸入:s = "abaacbcbb"
  • 頻率:['a' => 3、'b'=> 4、'c' => 2]
  • 減少後:
    • '一' => 2(從 3 減少),
    • 'b'=> 2(從 4 減少),
    • 'c'=> 2(無需減少)。
  • 最小長度:2 2 2 = 6。

範例2:

  • 輸入:s = "aa"
  • 頻率:['a' => 2]
  • 不需要減少,因為沒有字元的頻率為 3 或更多。
  • 最小長度:2。

複雜:

  1. 時間複雜度:

    • 計數頻率:O(n),其中 n 是字串的長度。
    • 減少:O(1)(恆定時間,因為只有 26 個小寫字母)。
    • 求和頻率:O(1).
    • 整體:O(n)
  2. 空間複雜度:

    • O(1),因為頻率陣列最多有 26 個條目。

這個解決方案非常高效,並且在問題的限制範圍內運作良好。

聯絡連結

如果您發現本系列有幫助,請考慮在 GitHub 上給 存儲庫 一個星號或在您最喜歡的社交網絡上分享該帖子? 。您的支持對我來說意義重大!

如果您想要更多類似的有用內容,請隨時關注我:

  • 領英
  • GitHub

以上是運算後字串的最小長度的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
在Laravel中使用Flash會話數據在Laravel中使用Flash會話數據Mar 12, 2025 pm 05:08 PM

Laravel使用其直觀的閃存方法簡化了處理臨時會話數據。這非常適合在您的應用程序中顯示簡短的消息,警報或通知。 默認情況下,數據僅針對後續請求: $請求 -

php中的捲曲:如何在REST API中使用PHP捲曲擴展php中的捲曲:如何在REST API中使用PHP捲曲擴展Mar 14, 2025 am 11:42 AM

PHP客戶端URL(curl)擴展是開發人員的強大工具,可以與遠程服務器和REST API無縫交互。通過利用Libcurl(備受尊敬的多協議文件傳輸庫),PHP curl促進了有效的執行

PHP記錄:PHP日誌分析的最佳實踐PHP記錄:PHP日誌分析的最佳實踐Mar 10, 2025 pm 02:32 PM

PHP日誌記錄對於監視和調試Web應用程序以及捕獲關鍵事件,錯誤和運行時行為至關重要。它為系統性能提供了寶貴的見解,有助於識別問題並支持更快的故障排除

簡化的HTTP響應在Laravel測試中模擬了簡化的HTTP響應在Laravel測試中模擬了Mar 12, 2025 pm 05:09 PM

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显著减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

在Codecanyon上的12個最佳PHP聊天腳本在Codecanyon上的12個最佳PHP聊天腳本Mar 13, 2025 pm 12:08 PM

您是否想為客戶最緊迫的問題提供實時的即時解決方案? 實時聊天使您可以與客戶進行實時對話,並立即解決他們的問題。它允許您為您的自定義提供更快的服務

解釋PHP中晚期靜態結合的概念。解釋PHP中晚期靜態結合的概念。Mar 21, 2025 pm 01:33 PM

文章討論了PHP 5.3中介紹的PHP中的晚期靜態結合(LSB),允許靜態方法的運行時間分辨率調用以更靈活的繼承。 LSB的實用應用和潛在的觸摸

自定義/擴展框架:如何添加自定義功能。自定義/擴展框架:如何添加自定義功能。Mar 28, 2025 pm 05:12 PM

本文討論了將自定義功能添加到框架上,專注於理解體系結構,識別擴展點以及集成和調試的最佳實踐。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),