3005. Count Elements With Maximum Frequency | LeetCode

vc7-avatar-img
發佈於LeetCode
更新 發佈閱讀 4 分鐘

每日一題

https://leetcode.com/problems/count-elements-with-maximum-frequency/description/?envType=daily-question&envId=2025-09-19

日期

2025/9/22

程式碼

以 Example 1 為例

Input: nums = [1,2,2,3,1,4]
class Solution {
func maxFrequencyElements(_ nums: [Int]) -> Int {
nums
// 1. 計算每一個數字出現幾次
// Output - [3: 1, 4: 1, 2: 2, 1: 2]
.reduce(into: [Int: Int]()) { $0[$1, default: 0] += 1 }
// 2. 計算每一種出現次數各自有幾次
// Output - [2: 2, 1: 2]
.reduce(into: [Int: Int]()) { $0[$1.value, default: 0] += 1 }
// 3. 找出最大數字次數出現次數
// Output - Optional((key: 2, value: 2))
// 敘述:出現 2 次 (key) 的有 2 個 (value) 數字
.max { $0.key < $1.key }
// 4. 算出題目想要的答案。
// 因為 .max 的返回值是 Optional ,所以需要 `?? 0`
// Output - 4
.map { $0.key * $0.value } ?? 0
}
}

grouped(by:)

送出之後看到 iamhands0me解法 ,才想到可以用 grouped(by:),但是邏輯上很神奇的大同小異。

在逐行看 output 就發現途中會生成一些 dictionary ,好奇會不會影響空間複雜度?但是程式碼本身是簡潔好讀多了。

class Solution {
func maxFrequencyElements(_ nums: [Int]) -> Int {
nums
// 1. 因為是分組,所以 `value` 是被群組起來的陣列
// [3: [3], 2: [2, 2], 4: [4], 1: [1, 1]]
.grouped(by: \.self)
// 2. 有保留 key-value 的 signature
// [1: [(key: 4, value: [4]), (key: 3, value: [3])], 2: [(key: 1, value: [1, 1]), (key: 2, value: [2, 2])]]
.grouped(by: \.value.count)
.max { $0.key < $1.key }
.map { $0.key * $0.value.count } ?? 0
}
}
留言
avatar-img
留言分享你的想法!
avatar-img
萱寫寫
2會員
16內容數
讀書心得、活動參加心得
萱寫寫的其他內容
2025/09/19
LeetCode 每日一題: 2025/09/19
2025/09/19
LeetCode 每日一題: 2025/09/19
2025/09/18
LeetCode 每日一題: 2025/09/18
2025/09/18
LeetCode 每日一題: 2025/09/18
2025/09/17
LeetCode 每日一題: 2025/09/17
2025/09/17
LeetCode 每日一題: 2025/09/17
看更多
你可能也想看
Thumbnail
在小小的租屋房間裡,透過蝦皮購物平臺採購各種黏土、模型、美甲材料等創作素材,打造專屬黏土小宇宙的療癒過程。文中分享多個蝦皮挖寶地圖,並推薦蝦皮分潤計畫。
Thumbnail
在小小的租屋房間裡,透過蝦皮購物平臺採購各種黏土、模型、美甲材料等創作素材,打造專屬黏土小宇宙的療癒過程。文中分享多個蝦皮挖寶地圖,並推薦蝦皮分潤計畫。
Thumbnail
小蝸和小豬因購物習慣不同常起衝突,直到發現蝦皮分潤計畫,讓小豬的購物愛好產生價值,也讓小蝸開始欣賞另一半的興趣。想增加收入或改善伴侶間的購物觀念差異?讓蝦皮分潤計畫成為你們的神隊友吧!
Thumbnail
小蝸和小豬因購物習慣不同常起衝突,直到發現蝦皮分潤計畫,讓小豬的購物愛好產生價值,也讓小蝸開始欣賞另一半的興趣。想增加收入或改善伴侶間的購物觀念差異?讓蝦皮分潤計畫成為你們的神隊友吧!
Thumbnail
題目敘述 Sort Array by Increasing Frequency Leetcode #1636 給定一個輸入陣列,請依照出現頻率的多寡從低頻到高頻排列陣列元素。 如果有兩個元素的出現頻率相同,依照元素大小從大到小排列。 測試範例 Example 1: Input: nums
Thumbnail
題目敘述 Sort Array by Increasing Frequency Leetcode #1636 給定一個輸入陣列,請依照出現頻率的多寡從低頻到高頻排列陣列元素。 如果有兩個元素的出現頻率相同,依照元素大小從大到小排列。 測試範例 Example 1: Input: nums
Thumbnail
中學數學基礎練習—一元一次方程式
Thumbnail
中學數學基礎練習—一元一次方程式
Thumbnail
中學數學基礎練習—一元一次方程式
Thumbnail
中學數學基礎練習—一元一次方程式
Thumbnail
高中數學主題練習—對數方程式
Thumbnail
高中數學主題練習—對數方程式
Thumbnail
高中數學主題練習—分點計算
Thumbnail
高中數學主題練習—分點計算
Thumbnail
高中數學主題練習—分點計算
Thumbnail
高中數學主題練習—分點計算
Thumbnail
給定一個字串陣列,請把它們所共有的字元伴隨著出現次數輸出。這篇文章介紹如何使用字典統計出現次數,和字典取交集的方法來解決此問題。並提供了複雜度分析和關鍵知識點。
Thumbnail
給定一個字串陣列,請把它們所共有的字元伴隨著出現次數輸出。這篇文章介紹如何使用字典統計出現次數,和字典取交集的方法來解決此問題。並提供了複雜度分析和關鍵知識點。
Thumbnail
Leetcode 精選75題 題目與題解 熱門考點 目錄 (持續更新中) 建議從左側目錄 或者 按Ctrl+F輸入關鍵字進行搜尋
Thumbnail
Leetcode 精選75題 題目與題解 熱門考點 目錄 (持續更新中) 建議從左側目錄 或者 按Ctrl+F輸入關鍵字進行搜尋
Thumbnail
題目敘述 題目會給定一個整數陣列arr,要求我們判斷是否每個元素的出現次數都不同? 題目的原文敘述 測試範例 Example 1: Input: arr = [1,2,2,1,1,3] Output: true Explanation: The value 1 has 3 occurre
Thumbnail
題目敘述 題目會給定一個整數陣列arr,要求我們判斷是否每個元素的出現次數都不同? 題目的原文敘述 測試範例 Example 1: Input: arr = [1,2,2,1,1,3] Output: true Explanation: The value 1 has 3 occurre
追蹤感興趣的內容從 Google News 追蹤更多 vocus 的最新精選內容追蹤 Google News