題意
給定一個整數陣列 m a t c h e s matches ma t c h es 其中 m a t c h e s [ i ] = [ w i n n e r i , l o s e r i ] matches[i] = [winner_i, loser_i] ma t c h es [ i ] = [ w inn e r i , l ose r i ] 表示在比賽中 球員 w i n n e r i winner_i w inn e r i 打敗了 球員 l o s e r i loser_i l ose r i 。
返回一個長度為 2 2 2 的列表 a n s w e r answer an s w er :
a n s w e r [ 0 ] answer[0] an s w er [ 0 ] 是所有 沒有 輸掉任何比賽的球員列表。
a n s w e r [ 1 ] answer[1] an s w er [ 1 ] 是所有恰好輸掉 一場 比賽的球員列表。
只需考慮參加過 至少一場 比賽的球員,且答案中的值都需按 遞增 順序返回。
思路:雜湊表(Hash Table) + 排序(Sorting)
使用一個雜湊表 c n t cnt c n t 來記錄每個球員的 輸掉比賽次數 ,然後對 c n t cnt c n t 的 key 進行排序,將 c n t [ k ] = 0 cnt[k] = 0 c n t [ k ] = 0 的球員加入到 a n s w e r [ 0 ] answer[0] an s w er [ 0 ] 中,將 c n t [ k ] = 1 cnt[k] = 1 c n t [ k ] = 1 的球員加入到 a n s w e r [ 1 ] answer[1] an s w er [ 1 ] 中。
但需要注意,由於我們在添加到 c n t cnt c n t 時,只對 l o s e r i loser_i l ose r i 進行 c n t cnt c n t 的增加,但考慮答案時也需要考慮到沒輸過的球員 ,因此可以另外維護一個 Hash Set p l a y e r s players pl a yers ,或是在 w i n n e r i winner_i w inn e r i 第一次出現時將其也添加到 c n t cnt c n t 中,並且初始化為 0 0 0 。
此外,由於我們只在意答案中的球員順序,因此也可以先添加到答案後,再對答案進行排序,這樣應該會略快一些。
複雜度分析
時間複雜度:O ( n log n ) \mathcal{O}(n \log n) O ( n log n ) ,主要是排序的時間複雜度。
空間複雜度:O ( n ) \mathcal{O}(n) O ( n ) ,使用雜湊表來記錄每個球員的輸掉比賽次數,而最多會有 2 n 2n 2 n 個球員。
Python C++
1 2 3 4 5 6 7 8 9 10 11 12 13 class Solution : def findWinners (self, matches: List [List [int ]] ) -> List [List [int ]]: cnt = defaultdict(int ) for x, y in matches: cnt[x] = cnt[x] cnt[y] += 1 ans = [[], []] for p in sorted (cnt.keys()): if cnt[p] == 0 : ans[0 ].append(p) elif cnt[p] == 1 : ans[1 ].append(p) return ans
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 class Solution {public : vector<vector<int >> findWinners (vector<vector<int >>& matches) { vector<vector<int >> ans (2 ); unordered_map<int , int > cnt; for (auto & match : matches) { int x = match[0 ], y = match[1 ]; if (!cnt.count (x)) cnt[x] = 0 ; cnt[y]++; } for (auto kv : cnt) { int k = kv.first, v = kv.second; if (cnt[k] == 0 ) ans[0 ].push_back (k); else if (cnt[k] == 1 ) ans[1 ].push_back (k); } sort (ans[0 ].begin (), ans[0 ].end ()); sort (ans[1 ].begin (), ans[1 ].end ()); return ans; } };
寫在最後
Cover photo is generated by @ゴリラの素材屋さん , thanks for their work!
從難度分可以看出,其實這題應該沒有到 Medium 的程度,只是簡單的雜湊表應用。