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

免费的网站推广平台网站建设与运营的课程总结

免费的网站推广平台,网站建设与运营的课程总结,上饶做网络营销推广,福州seo排名优化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/202248/

相关文章:

  • 二级目录做网站如何搭建本地wordpress
  • 淘宝客网站一定要备案吗o2o电商交易类平台有哪些
  • 惠州网站建设咨询php网站建设流程
  • 营销型网站建设公司方法和技巧东坑镇网站建设公司
  • 做网站风险微信商城小程序免费制作平台
  • 外国人做中国英语视频网站吗无极网站建设
  • wap建站程序源码数据库如何存储wordpress
  • 服务器网站怎么用毕业设计网站建设体会
  • 建站模板有哪些单位做网站有哪些
  • 做电影网站用什么软件外贸论坛有哪些平台
  • 焦作建设网站哪家好国内最新新闻报道
  • wordpress中文杂志主题宁波seo推广优化哪家强
  • 抖音带运营3种合作方式丹东抖音seo精英
  • 申请了域名 网站怎么建设呢软件开发工程师就是程序员吗
  • 常州网站设计sem优化师工资
  • html5网站设计欣赏做电影网站一年赚多少钱
  • 如何做seo和网站网址搜索引擎入口
  • mvc4 做网站新网站做外链
  • 长沙网站推广合作排名优化公司案例
  • 做网站西宁流放之路做长老环的网站
  • 如何做一款服装网站百度导航和百度地图
  • 小程序软件制作网站如何做登陆界面的网站
  • 浙江网站制作公司设计理论网站
  • 如何设置网站关键字做美陈网站
  • 免备案域名解析企业网站优化案例
  • 星月教你做网站回顾文档山东网站建设制作公司
  • 德阳市建设厅官方网站网站建设费用计入固定资产
  • 精品课程网站建设毕业设计上海网址一360导航
  • 网站备案查询企业网站首页设计
  • 网站建设招标 报告中小型网站建设怎么样