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

望牛墩镇做网站海外网络专线

望牛墩镇做网站,海外网络专线,做网站武汉首选,wordpress win20082024.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.shuangfujiaoyu.com/news/59784.html

相关文章:

  • 公路机电工程建设网站长春网站制作企业
  • 网页网站原型图占位符怎么做舆情监测分析系统
  • 怎么做购物网站郑州见效果付费优化公司
  • 美国做网站站长工具精华
  • 专门做音效的网站竞价推广账户托管费用
  • 台州知名网站网站建设方案设计书
  • wordpress自媒体主题破解关键词排名优化技巧
  • 专业移动微网站建设全网营销网络推广
  • 网盟官方网站seo 首页
  • 房屋室内设计百度站长工具seo综合查询
  • 湖南高端网站建设常德今日头条新闻
  • 天河网站建设服务企业推广文案
  • 完整网站开发看什么书百度官网链接
  • 工程建设数字化管理平台app下载seo外链工具软件
  • 物业公司网站建设千川推广官网
  • 中山网站建设找阿江福州360手机端seo
  • 河南省网架公司优化建议
  • 网站网页的优化方法设计培训学院
  • 如何建设平台型的网站网络销售工作靠谱吗
  • 做购物网站能否生存长沙网红打卡景点排行榜
  • 南山制作网站公司成人馆店精准引流怎么推广
  • 中航建设集团有限公司网站seo搜外
  • 做网站运营是有提成的吗百度极简网址
  • seo网站优化怎么做windows优化大师怎么下载
  • 烟台电子商务产业园网站建设电子商务网站建设与维护
  • seo网站排名优化价格社会新闻最新消息
  • 徐州市住房和城乡建设局网站首页百度平台联系方式
  • 陆金所 网站开发二部惠州seo排名优化
  • 山东专业网站建设2023年新闻热点事件摘抄
  • 政府类型网站建设方案兰州怎么提高网站的排名