日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

leetcode 721. Accounts Merge | 721. 账户合并(HashMap版并查集)

發布時間:2024/2/28 编程问答 50 豆豆
生活随笔 收集整理的這篇文章主要介紹了 leetcode 721. Accounts Merge | 721. 账户合并(HashMap版并查集) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目

https://leetcode.com/problems/accounts-merge/

題解

HashMap 版的并查集。參考了:leetcode 684. Redundant Connection | 684. 冗余連接(并查集)

class Solution {public List<List<String>> accountsMerge(List<List<String>> accounts) {Map<String, String> parent = new HashMap<>();Map<String, String> name = new HashMap<>();Map<String, Integer> size = new HashMap<>();// initfor (List<String> list : accounts) {name.put(list.get(1), list.get(0));parent.put(list.get(1), list.get(1));size.put(list.get(1), 1);for (int i = 2; i < list.size(); i++) {name.put(list.get(i), list.get(0));parent.put(list.get(i), list.get(i));size.put(list.get(i), 1);}}// union findfor (List<String> list : accounts) {for (int i = 2; i < list.size(); i++) {String r0 = findRoot(parent, list.get(1)); // r0會被修改,不能放在外層不變!!String r1 = findRoot(parent, list.get(i));if (r0.equals(r1)) continue;if (size.get(r0) > size.get(r1)) {parent.put(r1, r0);} else {parent.put(r0, r1);}size.put(r0, size.get(r0) + size.get(r1));size.put(r1, size.get(r0) + size.get(r1));}}HashMap<String, Set<String>> resMap = new HashMap<>();for (List<String> list : accounts) {for (int i = 1; i < list.size(); i++) {String root = findRoot(parent, list.get(i));resMap.computeIfAbsent(root, k -> new TreeSet<>());resMap.get(root).add(list.get(i));}}List<List<String>> result = new ArrayList<>();for (String root : resMap.keySet()) {List<String> list = new ArrayList<>();list.add(name.get(root));list.addAll(resMap.get(root));result.add(list);}return result;}// 從s開始一直往上找,直到不能再往上,找到代表節點,返回public String findRoot(Map<String, String> parent, String s) {String cur = s;while (!cur.equals(parent.get(cur))) {cur = parent.get(cur);}while (!s.equals(parent.get(s))) { // 路徑壓縮String next = parent.get(s);parent.put(s, cur);s = next;}return cur;} }

總結

以上是生活随笔為你收集整理的leetcode 721. Accounts Merge | 721. 账户合并(HashMap版并查集)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。