LeetCode 🟡 2024. Maximize the Confusion of an Exam
🔗 🟡 2024. Maximize the Confusion of an Exam 1643
tags: Biweekly Contest 62
字串(String)
滑動窗口(Sliding Window)
前綴和(Prefix Sum)
二分搜尋(Binary Search)
題意
一名老師正在編寫一份由 個是非題組成的考卷,每個題目的答案為 'T'
或 'F'
,老師想通過最大化連續相同答案的題目數量(連續多個正確或連續多個錯誤)來迷惑學生。
給定一個字串 ,其中 是第 個問題的正確答案。另給定一個整數 ,表示最多可以執行以下操作的次數:
- 在每次操作中,可以將任何問題的正確答案改為
'T'
或'F'
(也就是將 改為'T'
或'F'
)。
請返回在執行最多 次操作後,答案中連續 'T'
或 'F'
的最大數量。
思路:滑動窗口(Sliding Window)
首先先考慮 'T'
的情況,對於 'T'
以外的字元 (即 'F'
) ,可以透過修改來將其改為 'T'
,而修改次數最多為 次。因此可以將問題轉換為:找到一個最長的子字串,且子字串中 'F'
的個數不超過 個。對於 'F'
的情況同理,兩者的結果取最大值即可。
而上述目標可以透過 滑動窗口(Sliding Window) 來解決,以連續 'T'
的情況為例:
- 使用兩個指標 和 來維護一個窗口,分別代表當前窗口左邊界和右邊界。
- 使用 來記錄當前窗口內有多少個
'T'
以外的字元 (即'F'
) 。 - 使用 來記錄在所有滿足條件的窗口中,最大的窗口大小。
透過移動窗口的右端點 不斷將新的元素加入窗口,並檢查是否符合要求(即:窗口中與目標字元不同的數量是否小於或等於 )。
- 如果 ,則透過移動窗口的左邊界 來縮小窗口,直到再次滿足條件。
- 當滿足條件時,當前窗口的大小 ,更新答案。
由於我們需要檢查兩個情況,因此可以使用一個 helper
函數來實現。最後取 max(helper('T'), helper('F'))
即可。
複雜度分析
- 時間複雜度:,其中 是字串的長度。
- 空間複雜度:。
1 | class Solution: |
1 | class Solution { |
類題
寫在最後
Cover photo is remixed from @吃肥皂泡泡, thanks for their work!
本部落格所有文章除特別聲明外,均採用CC BY-NC-SA 4.0 授權協議。轉載請註明來源 十六個天亮!
評論
WalineGiscus