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

帮别人设计网站的网站吗网站关键词优化代理

帮别人设计网站的网站吗,网站关键词优化代理,b2b电子商务网站调研报告文字,宁波专业seo团队题目描述 小蓝负责一家科技公司的数据中心安全。该数据中心包含 N N N 台服务器,编号为 1 1 1 到 N N N,以及 M M M 条数据链路,编号为 1 1 1 到 M M M。每条数据链路都连接着两台服务器。 最近,数据中心遭到了网络攻击&a…

题目描述

小蓝负责一家科技公司的数据中心安全。该数据中心包含 N N N 台服务器,编号为 1 1 1 N N N,以及 M M M 条数据链路,编号为 1 1 1 M M M。每条数据链路都连接着两台服务器。

最近,数据中心遭到了网络攻击,病毒正在通过这些链路快速蔓延。为了阻止病毒扩散,小蓝需要采取紧急措施,对网络进行隔离。他计划进行一系列操作,每次操作都包含以下两个步骤:

  1. 确定当前网络中所有连通的服务器集群——即通过链路直接或间接相连的服务器集合。
  2. 对于每个连通的服务器集群,禁用该集群内编号最小的那条数据链路,以切断病毒传播的途径。

小蓝会重复执行上述操作,直到数据中心的所有数据链路都被禁用、整个数据中心的网络都被隔离。对此,请你帮助小蓝计算出,他总共需要进行多少次操作?

输入格式

输入数据第一行包含两个正整数 N N N M M M,分别表示服务器的数量和数据链路的数量。

接下来 M M M 行,每行包含两个正整数 u i u_i ui v i v_i vi,表示第 i i i 条数据链路连接的服务器编号。数据链路的编号按照输入顺序从上到下依次为 1 1 1 M M M

输出格式

输出一个整数,表示小蓝需要进行的操作次数。

输入输出样例 #1

输入 #1

5 3
1 2
2 3
4 5

输出 #1

2

说明/提示

【样例说明】

第一次操作:

  1. 识别两个连通的服务器集群:

    • 集群 1:服务器 ( 1 , 2 , 3 ) (1,2,3) (1,2,3)
    • 集群 2:服务器 ( 4 , 5 ) (4,5) (4,5)
  2. 对于集群 1,禁用编号最小的链路 1 − 2 1-2 12;对于集群 2,禁用编号最小的链路 4 − 5 4-5 45

第一次操作结束后,仅剩余一个连通的服务器集群:服务器 ( 2 , 3 ) (2,3) (2,3)

第二次操作:

  1. 识别剩余的连通服务器集群: 服务器 ( 2 , 3 ) (2,3) (2,3)
  2. 禁用编号最小的链路 2 − 3 2-3 23

第二次操作结束后,网络中不再有连通的服务器集群,隔离完成。总共需要 2 次操作。

【评测用例规模与约定】

对于 40 % 40\% 40% 的评测用例, 2 ≤ N ≤ 1 0 3 2 \leq N \leq 10^3 2N103 1 ≤ M ≤ min ⁡ ( N × ( N − 1 ) 2 , 2 × 1 0 3 ) 1 \leq M \leq \min(\frac{N \times (N-1)}{2}, 2 \times 10^3) 1Mmin(2N×(N1),2×103)

对于 100 % 100\% 100% 的评测用例, 2 ≤ N ≤ 1 0 5 2 \leq N \leq 10^5 2N105 1 ≤ M ≤ min ⁡ ( N × ( N − 1 ) 2 , 2 × 1 0 5 ) 1 \leq M \leq \min(\frac{N \times (N-1)}{2}, 2 \times 10^5) 1Mmin(2N×(N1),2×105)

💻 代码实现(语言:Java)

import java.util.*;public class Main {static int[] parent, size, depth;static int find(int x) {if (parent[x] != x) parent[x] = find(parent[x]);return parent[x];}static void union(int x, int y) {int fx = find(x);int fy = find(y);if (fx == fy) {// 同一个集合内,增加冗余边计数depth[fx]++;} else {// 合并集合,同时更新深度if (size[fx] < size[fy]) {int tmp = fx; fx = fy; fy = tmp;}parent[fy] = fx;size[fx] += size[fy];depth[fx] = Math.max(depth[fx], depth[fy]) + 1;}}public static void main(String[] args) {Scanner sc = new Scanner(System.in);int n = sc.nextInt(); // 服务器数量int m = sc.nextInt(); // 边数量int[] u = new int[m];int[] v = new int[m];for (int i = 0; i < m; i++) {u[i] = sc.nextInt();v[i] = sc.nextInt();}parent = new int[n + 1];size = new int[n + 1];depth = new int[n + 1];for (int i = 1; i <= n; i++) {parent[i] = i;size[i] = 1;}int maxDepth = 0;// 从后往前插入边(逆向模拟)for (int i = m - 1; i >= 0; i--) {union(u[i], v[i]);int root = find(u[i]);maxDepth = Math.max(maxDepth, depth[root]);}System.out.println(maxDepth);}
}

每天带你写一道程序设计题,讲思路,写代码,练算法。
(编程题来源于网络,代码与讲解为本人原创。)

题目来源(方便大家练习)

https://www.luogu.com.cn/problem/P12893
http://www.dtcms.com/wzjs/297614.html

相关文章:

  • 网站做sem能够提高收录量吗网络培训心得体会
  • 做 在线观看免费网站搜狐财经峰会直播
  • 做国际物流需要哪些网站网站设计服务企业
  • 珠海网络推广广州seo托管
  • 深圳市住房和建设局网站变更seo外包上海
  • 福永网站建设阿里关键词排名查询
  • 网站建设公司天强科技佛山网站营销推广
  • 帮客户做网站挣钱吗百度非企渠道开户
  • 蓟县做网站网游推广
  • 网站建设型网站横幅(banner)图片厦门网站关键词推广
  • 网站建设优化服务方案模板如何提高自己的营销能力
  • 官方网站建设手机银行网站权重查询
  • 微信视频网站建设多少钱软文发稿平台
  • 武汉专业做网站的公司有哪些seo电商运营是什么意思
  • html5 中文网站模板网站搜索引擎优化工具
  • 哈尔滨最好的网站建设公司seo属于什么职业部门
  • 新疆建设工程信息网网官网网站seo基础优化
  • 建设网站说只给前端源码是什么意思谷歌关键词工具
  • 淮安j经济开发区建设局网站万网域名注册官网阿里云
  • 网站建设公司工作流程湖南企业seo优化首选
  • 千万不要学数字媒体技术武汉seo网站推广培训
  • 找人做淘宝网站多少钱网站建设黄页视频
  • ps怎么做网站模板seo怎么发外链的
  • 毕节做网站优化百度云搜索引擎入口盘搜搜
  • 开发网络新技术的平台搜索引擎排名优化方案
  • 嵌入式培训班多少钱seo专业培训中心
  • 扁平化风格网站模板关键词优化软件排行
  • 保险网站源码数据分析培训
  • 哈尔滨网络科技公司网站网站运营怎么做
  • 网站打开显示站点目录为什么不能去外包公司