当前位置: 首页 > news >正文

金坛建设网站页面设计标准规范

金坛建设网站,页面设计标准规范,怎么做区块链网站,在线网站制作系统源码2024.3.2 题目来源我的题解方法一 深度优先搜索方法二 并查集 题目来源 力扣每日一题;题序:2368 我的题解 方法一 深度优先搜索 使用深度优先搜索实现,在搜索过程中根据restricted进行截停。 时间复杂度:O(n) 空间复杂度&#…

2024.3.2

      • 题目来源
      • 我的题解
        • 方法一 深度优先搜索
        • 方法二 并查集

题目来源

力扣每日一题;题序:2368

我的题解

方法一 深度优先搜索

使用深度优先搜索实现,在搜索过程中根据restricted进行截停。

时间复杂度:O(n)
空间复杂度:O(n)

int res=0;
public int reachableNodes(int n, int[][] edges, int[] restricted) {List<Integer>[] g=createTree(n,edges);boolean[] bRestricted=new boolean[n];for(int i:restricted){bRestricted[i]=true;}dfs(g,0,-1,bRestricted);return res;
}
public List<Integer>[] createTree(int n,int[][] edges){List<Integer>[] g=new ArrayList[n];for(int i=0;i<n;i++){g[i]=new ArrayList<>();}for(int[] t:edges){int from = t[0];int to = t[1];g[from].add(to);g[to].add(from);}return g;
}
public void dfs(List<Integer>[] g,int cur,int pre,boolean[] bRestricted){res++;for(int next:g[cur]){//防止循环遍历  并且不能是受限节点if(next!=pre&&!bRestricted[next])dfs(g,next,cur,bRestricted);}
}
方法二 并查集

如果忽略受限的点,树就会变成若干个连通块,要计算的就是 0号点所在连通块的大小。
因此,可以用并查集来不断地将点集进行合并,依次考虑每一条边,如果边上两个点都没有受限,那么合并这两个点的所在集合,否则跳过该边。最终查询 0号点所在连通块的大小即可。

时间复杂度:O(n×α(n)),其中 n 是无向树中点的个数,α是反阿克曼函数。使用路径压缩和按秩合并优化后的并查集,单次查询和合并操作的时间复杂度是 O(α(n)),通常比较小,可以忽略。
空间复杂度:O(n)

public int reachableNodes(int n, int[][] edges, int[] restricted) {boolean[] bRestricted=new boolean[n];for(int i:restricted){bRestricted[i]=true;}UF uf=new UF(n);for(int[] v:edges){//如果起始和结束节点有一个是受限的节点,则不合并if(bRestricted[v[0]]||bRestricted[v[1]]){continue;}uf.union(v[0],v[1]);}return uf.getCount();
}
class UF{private int count;private int parent[];public UF(int n){count=n;parent=new int[n];for (int i = 0; i < n; i++) {parent[i]=i;}}public void union(int p,int q){int parentP=find(p);int parentQ=find(q);if (parentP==parentQ)return;parent[parentQ]=parentP;count--;}public boolean isConnection(int p,int q){int parentP=find(p);int parentQ=find(q);return parentP==parentQ;}public int find(int x){if(parent[x]!=x){parent[x]=find(parent[x]);//路径压缩}return parent[x];}public int getCount(){int cnt=0;//找0所在的集合int rt=find(0);for(int i=0;i<parent.length;i++){if(rt==find(i))cnt++;}return cnt;}
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

http://www.yayakq.cn/news/709972/

相关文章:

  • 建设银行的官方网站网站建设模板犀牛云
  • 建设一个网站要多少钱上永远的吗html5做网站的好处
  • 个人微网站怎么做如何看出网站开发语言
  • 宇宙企画网站手机微信网站模板
  • 在手机上怎么做微电影网站吗黑马网站建设
  • 个人做淘宝客网站不能备案吗wordpress评论后可见
  • 上海网站建设代镇江京口区
  • 最好链接的网站建设苏州建设职业技术学院招聘信息网站
  • 吉林建设网站asp网站开发心得体会
  • 前端网站效果有哪些免费校园网站建设
  • 个人网站可以做导航租腾讯服务器做网站行吗
  • 外企网站建设公司网页模版设计
  • asp网站 会员注册关键词seo排名怎么样
  • 网站开发 沈阳十大编程语言
  • 网站建设行业淘宝装修模板WordPress系统配置要求
  • 网站建设常用的英文杭州网站建设 seo
  • 怎么建手机网站网络科技公司网站建设策划
  • 做外贸网站一般多少钱源代码
  • 惠东做网站公司易安卓做网站
  • 软件开发和网站开发哪个好中国企业网银怎么登录
  • wordpress个人展示网站适合夫妻二人观看的电视剧
  • 云南网站seo外包wordpress更改文章宽度
  • 品牌宝正式推出免费个人网站认证电子商务公司的名字
  • 一般网站后台都是哪里做网站数据怎么会丢失
  • 自己能否建设网站设计网页报价
  • 西安网站建设畅网免费相册制作app
  • 服装网站建设配色网站空间虚拟主机续费
  • 网站建设做网站怎么做如何自创网站
  • 网站建设横向发展纵向发展win7建设网站教程
  • 做网站后的总结wordpress 图片墙