力扣(LeetCode)1697. 检查边长度限制的路径是否存在(C++)

news2024/11/29 9:36:48

并查集+离线查询

由于评测系统对 v e c t o r vector vector 的排序可能较慢,使用结构体保存 v e c t o r vector vector ,接下来的查询和边集就对结构体操作。

结构体的属性 a a a 点 、 b b b 点 、 c c c 长度、 d d d 顺序。重载 < < < ,排序时按照 c c c 长度升序。

初始化并查集,然后处理查询。

由于边集和查询都按照长度升序,从左往右,依次遍历查询和长度,维护并查集,将长度小于查询的边插入并查集。维护完并查集之后,利用并查集 O ( 1 ) O(1) O(1) O ( l o g n ) O(logn) O(logn) 时间判断两点之间的连通性,维护答案,即为所求。

const int N = 100010;
struct Node{
    int a,b,c,d;
    bool operator < (const Node &t){
        return c<t.c;
    }
}e[N],q[N];
class Solution {
public:
    vector<int> p;
    int find(int x){
        if(p[x]!=x) p[x] = find(p[x]);
        return p[x];
    }
    vector<bool> distanceLimitedPathsExist(int n, vector<vector<int>>& ee, vector<vector<int>>& qq) {
        int m = ee.size(), k = qq.size();
        for(int i= 0 ;i<m;i++)
            e[i] = {ee[i][0],ee[i][1],ee[i][2]};
        for(int i = 0;i<k;i++)
            q[i] = {qq[i][0],qq[i][1],qq[i][2],i};
        sort(e,e+m),sort(q,q+k);
        p = vector<int>(n,0);
        for(int i = 0;i<n;i++) p[i] = i;
        vector<bool>ans(k,0);
        for(int i = 0,j=0;i<k;i++){
            while(j<m&&e[j].c<q[i].c){
                int a = e[j].a, b = e[j].b;
                p[find(a)] = find(b);
                j++;
            }
            ans[q[i].d]=find(q[i].a)==find(q[i].b);
        }
        return ans;
    }
};
  1. 时间复杂度 : O ( n l o g n ) O(nlogn) O(nlogn) , 变量过多,用无实义的 n n n 代指所有变量,整体时间复杂度是 O ( n l o g n ) O(nlogn) O(nlogn) 级别,感兴趣的读者可以自行分析 。
  2. 空间复杂度 : O ( m + k + n ) O(m+k+n) O(m+k+n) , 边的数量 m m m ,查询的数量 k k k ,点的数量 n n n ,并查集的空间复杂度 O ( n ) O(n) O(n) ,额外保存边集和查询的空间复杂度 O ( m + k ) O(m+k) O(m+k) ,总体空间复杂度 O ( m + k + n ) O(m+k+n) O(m+k+n)

AC

AC

致语

  • 理解思路很重要
  • 读者有问题请留言,清墨看到就会回复的。

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

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

相关文章

ssm+Vue计算机毕业设计校园图书漂流系统(程序+LW文档)

ssmVue计算机毕业设计校园图书漂流系统&#xff08;程序LW文档&#xff09; 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技…

C++基础篇之什么是 数据结构

&#x1f4d2;博客主页&#xff1a; ​​开心档博客主页​​ &#x1f389;欢迎关注&#x1f50e;点赞&#x1f44d;收藏⭐留言&#x1f4dd; &#x1f4cc;本文由开心档原创&#xff01; &#x1f4c6;51CTO首发时间&#xff1a;&#x1f334;2022年12月12日&#x1f334; ✉…

12.1、后渗透测试--提权

meterpreter提权方式&#xff1a; getsystem自动提权bypassuac提权migrate1、getsystem自动提权 meterpreter > getsystemgetsystem工作原理&#xff1a;getsystem创建一个新的Windows服务&#xff0c;设置为SYSTEM运行&#xff0c;当它启动时连接到一个命名管道。getsystem…

Java 线程池详解

线程池&#xff08;thread pool&#xff09;&#xff1a;一种线程使用模式。线程过多会带来调度开销&#xff0c;进而影响缓存局部性和整体性能。而线程池维护着多个线程&#xff0c;对线程统一管理。 使用线程池的优势 提高效率&#xff0c;创建好一定数量的线程放在池中&am…

技术分享 | 被测系统架构与数据流分析

深入了解测试过程中被测系统的架构与数据流&#xff0c;有助于理解业务逻辑&#xff0c;梳理业务用例以及促进部门协同。 更深的理解业务逻辑是指要分析公司是做什么的&#xff0c;公司的重要的商务决策是什么&#xff0c;公司内部数据流是怎么运行的&#xff0c;有哪些常见的…

数字孪生重点商业实践展示

数字孪生是一个系统或一组对象的虚拟表示。数字孪生背后的技术旨在准确反映系统的生命周期和应用程序&#xff0c;并使用机器学习、模拟和人工智能的组合来帮助在现实生活中运行之前对使用、问题或效率进行建模。如今&#xff0c;数字孪生技术的爆火离不开人们对其商业价值的看…

[C语言]指针进阶

[C语言]指针进阶 文章目录[C语言]指针进阶1.字符指针&#xff1a;2.指针数组&#xff1a;3.数组指针&#xff1a;4.&数组名VS数组名:5.数组指针的使用:6.数组参数、指针参数:6.1一维数组传参:6.2二维数组传参:6.3一级指针传参:6.4二级指针传参:7.函数指针:7.1如何保存函数的…

Ubuntu20.04下notify-send和cron结合使用

问题背景 今天学到一个Linux下一个很有趣的弹窗通知组件&#xff0c;名字叫notify-send&#xff0c;可以用如下方式简单调用。 notify-send hello-world可以立马看到效果。 不仅如此&#xff0c;他的图标、文字的样式等都可以定制&#xff0c;如&#xff1a; notify-send -u…

Python 编程的入门不二之选——Python编程:从入门到实践

最好的Python入门教材 你好&#xff0c;我是小雨青年&#xff0c;一名程序员。 今天我为你推荐一本Python入门级书籍——《Python编程&#xff1a;从入门到实践》&#xff08;第二版&#xff09;。 Python 是一种流行的、适用于各种领域的编程语言。对于初学者来说&#xff…

新来了个同事,设计模式用的是真优雅呀,代码如诗

之前有小伙伴私信我说看源码的时候感觉源码很难&#xff0c;不知道该怎么看&#xff0c;其实这有部分原因是因为没有弄懂一些源码实现的套路&#xff0c;也就是设计模式&#xff0c;所以本文我就总结了9种在源码中非常常见的设计模式&#xff0c;并列举了很多源码的实现例子&am…

十二月十三号作业驱动作业

成功移植内核源码 开发板可以挂在linux操作系统 添加led驱动到内核源码drivers/char目录下 打开linux内核源码进入drivers/char目录下打开Kconfig文件&#xff0c;对Kconfig文件进行分析 vi Kconfig 2.添加自己的LED灯驱动程序选项 10 config LED_DRIVER …

[C语言]指针初阶

[C语言]指针初阶 文章目录[C语言]指针初阶1.指针def:2.指针变量&#xff1a;3.指针和内存的关系&#xff1a;4.指针和指针类型:4.1指针类型&#xff1a;5.指针-整数:6.指针的解引用:7.野指针&#xff1a;7.1成因&#xff1a;7.2如何规避野指针:8.指针运算:8.1指针-整数&#xf…

C++11 多线程编程

因为之前有学习过c11的并发库&#xff0c;最近在搞项目准备复习&#xff0c;本节开始就重温一下这块内容打算连着写上几篇博客去记录一下.. 题外话get几个概念 1.进程是资源分配的基本单位&#xff0c;线程是调度的基本单位&#xff0c;注意基本二字&#xff0c;这并不意味着进…

jdk8-获取本机ip、判断ip范围、ip与long互转等

在配置nginx的ip白名单时候&#xff0c;会通过ip段进行配置&#xff08;如 10.10.10.10/24&#xff09;,就在思考这种配置怎么通过代码解析并判断&#xff0c;故通过搜索网络内容&#xff0c;并通过java编写测试代码。代码及说明来源网络&#xff0c;并进行了部分调整。故有疑问…

谷歌神秘项目曝光,能写代码还会改bug的AI,这。。。。

做一个程序员&#xff0c;压力有多大&#xff1f;反正&#xff0c;最近的一个传闻&#xff0c;是让码农们瑟瑟发抖...... 传说谷歌正在研发一个秘密的新项目&#xff0c;教AI写代码。据说&#xff0c;学会之后&#xff0c;AI不仅能写代码&#xff0c;还会修复bug。 写代码这件…

异次元发卡系统源码荔枝发卡V3.0

1.将源码上传到宝塔站点目录之后解压 2.去config目录下找到database.php文件配置数据库 3.导入数据库 4.切换php版本8.0 5.设置伪静态 伪静态代码 location ~* (runtime|application)/{ return 403; } location / { if (!-e $request_filename){ rewrite ^(.*)$ /index…

[附源码]Node.js计算机毕业设计防疫物资捐赠系统Express

项目运行 环境配置&#xff1a; Node.js最新版 Vscode Mysql5.7 HBuilderXNavicat11Vue。 项目技术&#xff1a; Express框架 Node.js Vue 等等组成&#xff0c;B/S模式 Vscode管理前后端分离等等。 环境需要 1.运行环境&#xff1a;最好是Nodejs最新版&#xff0c;我…

物联网设备预警解决方案

物联网设备管理平台整合互亿无线预警解决方案&#xff0c;可以将设备预警信息第一时间通知到管理、维护人员。 场景应用示例&#xff1a; 设备**报错&#xff0c;报错类型为**&#xff0c;请及时排查。 温度监控系统&#xff0c;**设备&#xff0c;当前湿度&#xff1a;**&a…

VTK-vtkCleanPolyData/vtkQuantizePolyDataPoints

小结&#xff1a;本文主要讲述vtk中vtkCleanPolyData过滤器的作用和实现原理&#xff0c;希望对各位小伙伴能有所帮助&#xff01; 示例&#xff1a; 将下图进行Clean&#xff0c;设置Tolerance为0.01&#xff08;相对误差&#xff09;。 vtkCleanPolyData …

[附源码]Python计算机毕业设计SSM基于JAVA语言的国货美妆店管理系统(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…