力扣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;
      }
  };
相关推荐
王中阳Go1 小时前
从超市收银到航空调度:贪心算法如何破解生活中的最优决策谜题?
java·后端·算法
故事挺秃然2 小时前
中文分词:机械分词算法详解与实践总结
算法·nlp
车队老哥记录生活4 小时前
【MPC】模型预测控制笔记 (3):无约束输出反馈MPC
笔记·算法
地平线开发者5 小时前
BEV 感知算法评价指标简介
算法·自动驾驶
不过四级不改名6775 小时前
用c语言实现简易c语言扫雷游戏
c语言·算法·游戏
C++ 老炮儿的技术栈7 小时前
手动实现strcpy
c语言·开发语言·c++·算法·visual studio
倔强的石头_7 小时前
【数据结构与算法】利用堆结构高效解决TopK问题
后端·算法
倔强的石头_8 小时前
【数据结构与算法】详解二叉树下:实践篇————通过链式结构深入理解并实现二叉树
后端·算法
哎写bug的程序员8 小时前
leetcode复盘(1)
算法·leetcode·职场和发展
风靡晚8 小时前
用于汽车毫米波雷达的四维高分辨率点云图像
人工智能·算法·机器学习·计算机视觉·汽车·信息与通信·信号处理