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

网站做外链软件百度知道首页登录

网站做外链软件,百度知道首页登录,广东哪家网站建设网页设计服务,做号网站并查集 // 1.初始化 int fa[MAXN]; void init(int n) {for (int i1;i<n;i)fa[i]i; }// 2.查询 找到的祖先直接返回&#xff0c;未进行路径压缩 int.find(int i){if(fa[i] i)return i;// 递归出口&#xff0c;当到达了祖先位置&#xff0c;就返回祖先elsereturn find(fa[i])…

并查集

// 1.初始化
int fa[MAXN];
void init(int n)
{for (int i=1;i<=n;++i)fa[i]=i;
}// 2.查询
找到的祖先直接返回,未进行路径压缩
int.find(int i){if(fa[i] == i)return i;// 递归出口,当到达了祖先位置,就返回祖先elsereturn find(fa[i]);// 不断往上查找祖先
}// 3.合并
void unionn(int i,int j)int i_fa=find(i);// 找到i的祖先    int j_fa=find(j);// 找到j的祖先fa[i_fa]=j_fa;// i的祖先指向j的祖先。
}

路径压缩,也就是在某一次find函数执行过程中,更新子节点的指向,直接指向顶级节点

107.寻找存在的路径

题目:107. 寻找存在的路径 (kamacoder.com)

思路:难道说,使用并查集的find函数,遍历所有的边,将节点的父亲信息存起来,如果source和destination没有指向同一个根节点,那么就说明不存在路径

尝试(不对)
import java.util.*;class Main{public static int n;public static int m;public static int[] fa;public static void main(String[] args){Scanner scanner = new Scanner(System.in);n = scanner.nextInt();m = scanner.nextInt();fa = new int[n];for(int i = 0; i<n; i++){fa[i] = i;}for(int i = 0; i<m; i++){int n1 = scanner.nextInt();int n2 = scanner.nextInt();union(n1,n2);}int source = scanner.nextInt();int destination = scanner.nextInt();if(source == find(destination)){System.out.println(1);}else{System.out.println(0);}}public static void union(int i , int j){int i_fa = find(i);int j_fa = find(j);fa[i_fa] = j_fa;}public static int find(int j){if(j==fa[j])return j;else{fa[j] = find(fa[j]);return fa[j];}}
}
答案
import java.util.Scanner;public class Main {private static int[] father;public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt(); // 节点数量int m = scanner.nextInt(); // 边的数量// 初始化并查集father = new int[n + 1];init(n);// 读取边并构建并查集for (int i = 0; i < m; i++) {int s = scanner.nextInt();int t = scanner.nextInt();join(s, t);}int source = scanner.nextInt(); // 起始节点int destination = scanner.nextInt(); // 目标节点// 判断是否在同一个集合中if (isSame(source, destination)) {System.out.println(1);} else {System.out.println(0);}}// 并查集初始化private static void init(int n) {for (int i = 1; i <= n; i++) {father[i] = i;}}// 并查集里寻根的过程private static int find(int u) {if (u != father[u]) {father[u] = find(father[u]);}return father[u];}// 判断 u 和 v 是否找到同一个根private static boolean isSame(int u, int v) {return find(u) == find(v);}// 将 v -> u 这条边加入并查集private static void join(int u, int v) {int rootU = find(u);int rootV = find(v);if (rootU != rootV) {father[rootV] = rootU;}}
}
小结

http://www.ds6.com.cn/news/7152.html

相关文章:

  • 做暧昧的小视频网站2台州seo排名公司
  • dw网站开发环境优秀的网页设计网站
  • 宁德网站推广杭州推广公司排名
  • 网页设计与制作怎么把图片加进去seo关键词排名优化怎么样
  • perl 动态网站开发广州抖音推广公司
  • 网站前端做报名框创建自己的网站
  • 私人做网站收费g3云推广
  • 做门户网站广告市场调研怎么做
  • 南通做网站的公司推广策略怎么写
  • 网站怎么做自适应政府免费培训 面点班
  • 正规的h5网站宁波seo排名外包
  • 得到app公司广州seo排名优化服务
  • 毕业设计做音乐网站可以吗百度收录时间
  • 怎么做像表白墙的网站软文范例200字
  • 教做黏土手工的网站淘宝交易指数换算工具
  • 做网站设计师的感想实事新闻热点
  • wordpress导航图标代码关键词优化排名软件s
  • 辽宁省和城乡建设厅网站网络营销理论
  • 网站开发入门书籍推荐人际网络营销2900
  • 宁波网站建设设计制作方案与价格seopeix
  • 赣州网红打卡旅游景点百度快速优化排名软件
  • 网站首页鲁大师广告投放平台都有哪些
  • 网站关键词推广上海百度搜索排名优化
  • wordpress 添加样式表seo排名的职位
  • 企业咨询顾问的工作内容seo站内优化和站外优化
  • 做水军那些网站好长沙网站seo服务
  • 商务网站内容维护和管理的范围免费一键搭建网站
  • 网站维护提示代码地推公司
  • 如何百度到自己的网站seo管理系统培训运营
  • 做衬衫的网站网络营销经典成功案例