力扣721.账户合并

力扣721.账户合并

  • 并查集 + dfs

    • 哈希表以地址为下标 存账户下标数组
    • 遍历每个账户下标
    • 其中的每个email如果还对应其他下标(说明两下标对应的账户名称一样 可以合并)
    • 那么继续dfs
cpp 复制代码
  class Solution {
  public:
      vector<vector<string>> accountsMerge(vector<vector<string>>& accounts) {
          unordered_map<string,vector<int>> email_to_idx;
          for(int i=0;i<accounts.size();i++)
              for(int k=1;k<accounts[i].size();k++)
                  email_to_idx[accounts[i][k]].push_back(i);
          unordered_set<string> email_set;
          //记录每个下标是否遍历过
          vector<int> vis(accounts.size());
          auto dfs = [&](auto &&dfs,int i) ->void
          {
              vis[i] = true;
              //遍历其中每个地址
              for(int k=1;k<accounts[i].size();k++)
              {
                  string &email = accounts[i][k];
                  if(email_set.contains(email))
                      continue;
                  //没有放进来过 就插入 并看是否有其他下标也包含这个地址
                  email_set.insert(email);
                  for(int j:email_to_idx[email])
                      if(!vis[j])
                          dfs(dfs,j);
              }
          };
          vector<vector<string>> res;
          for(int i=0;i<vis.size();i++)
          {
              //dfs过就continue
              if(vis[i]) 
                  continue;
              email_set.clear();
              dfs(dfs,i);
              //账户名称 + 账户地址的集合(字典序排序) 放入答案
              vector<string> cur = {accounts[i][0]};
              cur.insert(cur.end(),email_set.begin(),email_set.end());
              sort(cur.begin()+1,cur.end());
              res.push_back(cur);
          }
          return res;
      }
  };
相关推荐
StarPrayers.10 小时前
旅行商问题(TSP)(2)(heuristics.py)(TSP 的两种贪心启发式算法实现)
前端·人工智能·python·算法·pycharm·启发式算法
爱吃橘的橘猫10 小时前
嵌入式系统与嵌入式 C 语言(2)
c语言·算法·嵌入式
2351610 小时前
【LeetCode】146. LRU 缓存
java·后端·算法·leetcode·链表·缓存·职场和发展
weixin_3077791311 小时前
使用Python高效读取ZIP压缩文件中的UTF-8 JSON数据到Pandas和PySpark DataFrame
开发语言·python·算法·自动化·json
柳安忆11 小时前
【论文阅读】Sparks of Science
算法
web安全工具库12 小时前
从课堂笔记到实践:深入理解Linux C函数库的奥秘
java·数据库·算法
爱编程的鱼13 小时前
C# 变量详解:从基础概念到高级应用
java·算法·c#
tkevinjd14 小时前
反转链表及其应用(力扣2130)
数据结构·leetcode·链表
HalvmånEver14 小时前
红黑树实现与原理剖析(上篇):核心规则与插入平衡逻辑
数据结构·c++·学习·算法·红黑树
哆啦刘小洋14 小时前
T:堆的基本介绍
算法