721.力扣每日一题7/15 Java(并查集)

  • 博客主页:音符犹如代码
  • 系列专栏:算法练习
  • 关注博主,后期持续更新系列文章
  • 如果有错误感谢请大家批评指出,及时修改
  • 感谢大家点赞👍收藏⭐评论✍

目录

解题思路

解题过程

时间复杂度

空间复杂度

Code


解题思路

本题的解题思想主要是利用并查集(Union Find)数据结构来合并具有相同账户名称的邮箱地址。首先,我们遍历所有账户信息,建立邮箱地址到唯一索引的映射(emailToIndex)和邮箱地址到账户名称的映射(emailToName)。这样做是为了能够快速地在后续步骤中查找邮箱的索引和对应的账户名称。

然后,我们使用并查集来跟踪哪些邮箱地址应该被合并到同一个账户中。对于每个账户,我们将其中的第一个邮箱地址作为代表,并将其与账户中的其他邮箱地址进行合并操作。这样,属于同一账户的邮箱地址在并查集中就会有相同的根节点。

最后,我们遍历所有邮箱地址,根据并查集的结果将它们分组到对应的账户中。对于每个组(即每个并查集的根节点),我们收集其下所有的邮箱地址,并从任意一个邮箱地址中获取对应的账户名称(因为我们已经假设了每个账户内的邮箱地址都关联到同一个名称)。然后,我们将账户名称和收集到的邮箱地址列表添加到结果列表中。

解题过程

  1. 初始化映射和计数器:创建emailToIndexemailToName映射,以及一个计数器emailsCount来跟踪邮箱地址的数量。

  2. 建立映射:遍历accounts列表,为每个邮箱地址分配一个唯一索引,并将其与账户名称关联起来。

  3. 构建并查集:创建UnionFind对象,并根据emailToIndex中的索引进行邮箱地址的合并操作。

  4. 分组邮箱地址:遍历所有邮箱地址,根据并查集的结果将它们分组到对应的账户中。

  5. 构建结果列表:对于每个分组,收集其下的邮箱地址,并从任意一个邮箱地址中获取账户名称,然后构建并添加到结果列表中。

时间复杂度

  • 遍历 accounts 列表建立映射的时间复杂度可以简化为 O(n),其中 n 是邮箱地址的总数(即 E)。
  • 构建并查集和进行合并操作的时间复杂度也是 O(n),因为每个邮箱地址最多被合并一次,并且 union 操作在并查集中通常是高效的。
  • 分组邮箱地址和构建结果列表的时间复杂度同样是 O(n),因为我们需要遍历所有邮箱地址一次。

因此,总的时间复杂度可以表示为 O(n),其中 n 是邮箱地址的总数。

空间复杂度

  • emailToIndexemailToName 映射和并查集都需要存储与邮箱地址数量成比例的信息,因此它们的空间复杂度都是 O(n)。
  • 结果列表的空间复杂度也是 O(n),因为每个邮箱地址在结果列表中只会出现一次(尽管它们被分组到了不同的账户中)。

因此,总的空间复杂度同样可以表示为 O(n),其中 n 是邮箱地址的总数。

Code

class Solution {public List<List<String>> accountsMerge(List<List<String>> accounts) {Map<String, Integer> emailToIndex = new HashMap<String, Integer>();Map<String, String> emailToName = new HashMap<String, String>();int emailsCount = 0;for (List<String> account : accounts) {String name = account.get(0);int size = account.size();for (int i = 1; i < size; i++) {String email = account.get(i);if (!emailToIndex.containsKey(email)) {emailToIndex.put(email, emailsCount++);emailToName.put(email, name);}}}UnionFind uf = new UnionFind(emailsCount);for (List<String> account : accounts) {String firstEmail = account.get(1);int firstIndex = emailToIndex.get(firstEmail);int size = account.size();for (int i = 2; i < size; i++) {String nextEmail = account.get(i);int nextIndex = emailToIndex.get(nextEmail);uf.union(firstIndex, nextIndex);}}Map<Integer, List<String>> indexToEmails = new HashMap<Integer, List<String>>();for (String email : emailToIndex.keySet()) {int index = uf.find(emailToIndex.get(email));List<String> account = indexToEmails.getOrDefault(index, new ArrayList<String>());account.add(email);indexToEmails.put(index, account);}List<List<String>> merged = new ArrayList<List<String>>();for (List<String> emails : indexToEmails.values()) {Collections.sort(emails);String name = emailToName.get(emails.get(0));List<String> account = new ArrayList<String>();account.add(name);account.addAll(emails);merged.add(account);}return merged;}
}
class UnionFind {  private int[] parent;  public UnionFind(int size) {  parent = new int[size];  for (int i = 0; i < size; i++) {  parent[i] = i;  }  }  public int find(int x) {  if (parent[x] != x) {  parent[x] = find(parent[x]); // 路径压缩  }  return parent[x];  }  public void union(int x, int y) {  int rootX = find(x);  int rootY = find(y);  if (rootX != rootY) {  parent[rootX] = rootY;  }  }  
}

 

你担心什么,什么就控制你——约翰·洛克(John Locke)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/48723.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

有什么图片转word 免费软件?6个软件帮助你快速转换文件

有什么图片转word 免费软件&#xff1f;6个软件帮助你快速转换文件 转换图片到Word文档的免费软件通常包括一些在线工具和桌面应用程序&#xff0c;它们可以帮助用户将图片中的文本提取并转换为可编辑的Word格式。以下是六个推荐的免费软件&#xff1a; 迅捷文字识别&#xff…

【深度学习教程】

文章目录 pytorch官方教程知识蒸馏&#xff1a;https://pytorch.org/tutorials/beginner/knowledge_distillation_tutorial.html 李宏毅-机器学习/深度学习https://speech.ee.ntu.edu.tw/~hylee/ml/2021-spring.phphttps://speech.ee.ntu.edu.tw/~hylee/ml/2022-spring.phphttp…

【LeetCode】day18:530 - 二叉搜索树的最小绝对差, 501 - 二叉搜索树中的众数, 236 - 二叉树的最近公共祖先

LeetCode 代码随想录跟练 Day18 530.二叉搜索树的最小绝对差501.二叉搜索树中的众数236.二叉树的最近公共祖先 530.二叉搜索树的最小绝对差 题目描述&#xff1a; 给你一个二叉搜索树的根节点 root &#xff0c;返回 树中任意两不同节点值之间的最小差值 。 差值是一个正数&am…

基于组态王和S7-200实现传感器连接的简单人机界面

在当今社会&#xff0c;工业自动化正以前所未有的速度发展&#xff0c;成为推动经济增长和提升生产效率的关键因素之一。随着科技的不断进步&#xff0c;自动化不仅仅是制造业的专利&#xff0c;也逐渐渗透到农业、交通、建筑等各个领域&#xff0c;为人们的生活带来了诸多变革…

工作纪实53-log4j日志打印文件隔离

在项目中&#xff0c;我有一堆业务日志需要打印&#xff0c;另一部分的日志&#xff0c;是没有格式的&#xff0c;需要被云平台离线解析并收集到kafka或者hdfs、hive等&#xff0c;需要将日志隔离打印到不同的文件 正常的log4j配置是下面这样的&#xff0c;配合Sl4j直接使用默认…

linux中创建一个名为“thread1“,堆栈大小为1024,优先级为2的线程

在Linux中&#xff0c;直接创建一个具有特定堆栈大小和优先级的线程通常不是通过标准的POSIX线程&#xff08;pthread&#xff09;库直接支持的。POSIX线程库&#xff08;pthread&#xff09;提供了创建和管理线程的基本机制&#xff0c;但不直接支持设置线程的堆栈大小或优先级…

星际漫游闪耀LEC授权展,COSMOSPANDA星际熊猫与BUNBUNX包小冥共绘国潮新篇章

上海&#xff0c;2024年7月17日 —— 在全球瞩目的2024年LEC全球授权展上海站盛大开幕之际&#xff0c;星际漫游携其两大国潮明星IP——COSMOSPANDA星际熊猫与bunbunx包小冥精彩亮相&#xff0c;为现场观众带来了一场融合视觉与文化的国潮盛宴。 展位盛况空前&#xff0c;国潮…

TDengin基础应用

一、框架的概念理解 之所以先介绍这块&#xff0c;是由于建库建表配置参数时需要用到&#xff0c;对参数的理解才能更好发挥数据库的性能与数据的高可用&#xff0c;可能理解的不够透彻&#xff0c;欢迎指正&#xff0c;先上官网的介绍&#xff1a; 整体架构 | TDengine 文档…

【Python】 探索 Python 中的 enumerate 方法

为何每次早餐 仍然魂离魄散 原来 那朝分手都要啜泣中上班 明明能够过得这关 赢回旁人盛赞 原来 顽强自爱这样难 难得的激情总枉费 残忍的好人都美丽 别怕 你将无人会代替 &#x1f3b5; 陈慧娴《情意结》 在 Python 编程中&#xff0c;遍历序列是非常常见…

uniapp封装请求拦截器,封装请求拦截和响应拦截的方法

首先我们先看一下uni官方给开发者提供的uni.request用来网络请求的api 1 2 3 4 5 6 7 8 9 uni.request({ url: , method: GET, data: {}, header: {}, success: res > {}, fail: () > {}, complete: () > {} }); 可以看到我们每次请求数据的时候都需…

pytest-fixture

资料来源&#xff1a;虫师2020的个人空间-虫师2020个人主页-哔哩哔哩视频 支持类似unittest风格的fixture&#xff0c;即setup和teardown class类中的方法分类 类方法可以直接调用&#xff0c;需要添加装饰器&#xff0c;修改类中的变量 实例方法&#xff0c;需要先实例化&…

构建稳固与安全的网络环境:从微软蓝屏事件中的教训学习

近日&#xff0c;一场由微软视窗系统软件更新引发的全球性“微软蓝屏”事件震惊了整个科技界。这次事件不仅暴露了现代IT基础设施在面对大规模软件缺陷时的脆弱性&#xff0c;也引发了对网络安全与系统稳定性的深刻思考。在本文中&#xff0c;我们将探讨这次事件的根源、影响以…

【C++】C++内存泄漏介绍及解决方案

文章目录 一.C内存泄漏是什么二.C内存泄漏的几种类型二.解决内存泄漏的方法 一.C内存泄漏是什么 在C中&#xff0c;内存泄漏&#xff08;Memory Leak&#xff09;是指由于疏忽或错误导致无法释放已分配的内存。内存泄漏通常发生在动态内存分配后&#xff0c;由于某些原因&…

【移动应用开发】创建Hello World应用

目录 一、安装Android Studio &#xff08;2023.1.28&#xff09; 二、创建HelloWorld的项目 1. 新建一个项目&#xff0c;选择Empty Views Activity 2. 点击next之后&#xff0c;为项目命名为HelloWorld 3. 点击Finish之后等待项目创建 三、观察项目结构 1. 选择以Proj…

预测性营销与开源AI智能名片商城系统的融合创新:探索数据驱动的营销新纪元

摘要&#xff1a;在当今这个数据驱动的时代&#xff0c;企业面临着前所未有的市场复杂性和消费者行为的快速变化。为了在这样的环境中保持竞争力并实现持续增长&#xff0c;预测性营销已成为企业不可或缺的战略工具。本文深入探讨了预测性营销的基本原理、技术架构及其在市场营…

nginx的安装和使用

nginx可以把项目部署到多台服务器提供并发量 安装nginx 一、安装依赖&#xff1a;yum install -y gcc-c pcre pcre-devel zlib zlib-devel openssl openssl-devel 二、下载nginx&#xff1a;https://nginx.org/en/download.html 三、创建安装路径&#xff1a;mkdir /usr/nginx …

论c++中的GUI

前言 hello大家好啊&#xff0c;这里是文宇&#xff0c;不是文字&#xff0c;是文宇哦 GUI&#xff08;图形用户界面&#xff09;是一种通过图形方式来与计算机系统进行交互的用户界面。C是一种强大的编程语言&#xff0c;可以用于开发GUI应用程序。在本文中&#xff0c;我将…

常用注意力机制 SENet CBAM ECA

在处理脑电信号时通常会用到一些注意力机制,来给不同的脑电通道不同的权重,进而体现出不同脑电通道在分类中的重要性。下面整理几种常见的通道注意力机制,方便以后查阅。 常用注意力机制 SENet CBAM ECA 注意力机制SENet(Squeeze-and-Excitation Network)SENet原理SENet P…

从Oracle到PostgreSQL:详细对比与迁移工具说明

1. 引言 在现代数据库管理中&#xff0c;选择合适的数据库系统对业务的成功至关重要。PostgreSQL和Oracle都是功能强大的数据库管理系统&#xff0c;各有其独特的优势和特点。本文将从数据类型、SQL语法、存储过程和函数、工具支持等方面对比PostgreSQL和Oracle&#xff0c;并…

MySQL相关知识

一、什么是数据库&#xff1f; 数据库&#xff08;Database&#xff0c;简称DB&#xff09;概念&#xff1a; 长期存放在计算机内&#xff0c;有组织、可共享的大量数据的集合&#xff0c;是一个 数据“仓库”。 二、数据库的特点&#xff1a; 1.结构化&#xff1a;数据在数…