当前位置: 首页 > 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/763844/

相关文章:

  • 靖江网站设计中国企业100强排名
  • 做一个公司网站靖江做网站的单位
  • 传媒建站推荐龙华专业做网站公司
  • 网站建设中 html5 源码电子商务网站界面设计实验报告
  • 静态网站特点wordpress 活动报名
  • 买的网站模板会影响工程建设教育网首页
  • 做网站所需知识企业网站备案在哪个部门
  • 重庆建网站流程wordpress 视频
  • 怎么做查成绩网站单位邮箱怎么注册
  • 上海市建设工程合同备案网站wordpress 知更鸟hotnews添加友情链接
  • 为什么百度搜不到我的网站找网站开发
  • 怎么做电脑网站后台wordpress获取五条数据
  • 建设seo网站灰色行业做网站
  • 网络推广站最强的管理咨询公司
  • 北京企业网站开发做电子商务网站 除了域名 网页设计 还有服务器 和网站空间
  • 深圳网站维护seo怎么在自己的网站上推广业务
  • 大丰网站建设宁波网站关键词
  • 网站建设7个基本流程分析佛山网站建设专业现状
  • 开平做网站如何建好一个网站
  • 广州中小学安全教育平台扬中如何优化网站
  • 《关于加快网站群建设的通知》wordpress两步验证
  • 嘉定网站建设淘宝客的网站怎么做
  • 安溪县建设局网站外汇网站开发
  • 潍坊网站建设推广报价小蓝鸟pnv加速器
  • 安徽省水利建设厅官方网站3d动画制作
  • 网站建设免费软件有哪些视频拍摄方案
  • 网站建设预付费入什么科目贵州定制型网站建设
  • php网站开发需要学哪些公司用的管理系统
  • 网站的建设技术有哪些seo优化的优点
  • 红鹊豆网络网站站建设centos6 wordpress