LeetCode 🟢 409. Longest Palindrome
🔗 🟢 409. Longest Palindrome
tags: 貪心(Greedy)
雜湊表(Hash Table)
計數(Counting)
題意
給定一個由小寫和大寫字母構成的字串 ,返回透過這些字母構造成的最長的 迴文(Palindrome) 字串的長度。
在構造過程中,請注意區分大小寫。例如 不能當做一個迴文字串。
思路:貪心(Greedy) + 計數(Counting)
為了最大化地使用字母構造迴文,需注意到迴文的特性:
- 迴文的兩側應該是對稱的,所以每個字母必須成對出現。
- 一個迴文可以有一個中心點,這個中心點可以是一個未成對的字母。
- 因此,每個出現偶數次的字母都可以完全使用;而出現奇數次的字母也可以使用,只是其中一個字母將會作為中心點。
具體步驟:
- 計算每個字母出現的次數。
- 統計每個字母貢獻的對數,即將每個字母出現次數除以 2 取整數部分,並將其加總。
- 如果出現了奇數次字母,可以保留一個作為中心點。
- 返回統計的對數乘以 2,再加上是否有中心點的標誌。
在 計數(Counting) 的方法上,可以使用 雜湊表(Hash Table) ,但由於已知字母只有 52 個,所以也可以使用一個長度為 52 的陣列來計數。
複雜度分析
- 時間複雜度 ,其中 為字串 的長度。
- 空間複雜度 。
1 | class Solution: |
1 | class Solution { |
寫在最後
Cover photo is generated by @たろたろ, thanks for their work!
這篇文章的寫作風格應該能看出明顯的不同,原因我以前都是用 CoPilot
來輔助寫作,而這次則是先由 GPT-4o
生成說明文字後,再做一些修改。不得不說在這種簡單題的思路說明上,LLM 做得比我好多了。
本部落格所有文章除特別聲明外,均採用CC BY-NC-SA 4.0 授權協議。轉載請註明來源 十六個天亮!
評論
WalineGiscus