华为OD机试真题 Java 实现【城市聚集度】【2023 B卷 200分】,附详细解题思路

news2025/2/19 8:12:40

在这里插入图片描述

目录

    • 专栏导读
    • 一、题目描述
    • 二、输入描述
    • 三、输出描述
    • 四、解题思路
    • 五、Java算法源码
    • 六、效果展示
      • 1、输入
      • 2、输出
      • 3、说明

华为OD机试 2023B卷题库疯狂收录中,刷题点这里

专栏导读

本专栏收录于《华为OD机试(JAVA)真题(A卷+B卷)》。

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

在这里插入图片描述

一、题目描述

一张地图上有N个城市,城市和城市之间有且只有一条道路相连,要么直接相连,要么通过其他城市中转相连(可中转一次或多次)。城市与城市之间的道路都不会成环。

当切断通往某城市i的所有道路后,地图上将分成多个连通的城市群,设该城市i的聚集度为DPi of Polymerization), DPi = max(城市群1的城市个数,城市群2的城市个数,…城市群m的城市个数)。 请找出地图上DP值最小的城市(即找到城市j,使得DPj = min(DP1,DP2…DPn))。

提示:如果有多个城市都满足条件,这些城市都要找出来(可能存在多个解)。
提示:DPi的计算,可以理解为已知一个树,删除某个节点后,生成的多个字树,求解多个字树节点数的问题。

二、输入描述

每个样例,第一行有一个整数N,表示有N个节点,1 <=N <=1000
j接下来的N-1行每行有两个整数x,y,表示城市x与城市y连接。1 <= x , y <= N

三、输出描述

输出城市的编号,如果有多个,按照编号升序输出。

四、解题思路

  1. 输入一张地图上有N个城市;
  2. 输入n-1条关系;
  3. 定义最小的最大连通块大小min;
  4. 定义最小的最大连通块所在的城市cityList;
  5. 遍历每个城市作为特殊城市;
    • 初始化并查集;
    • 将与特殊城市相连的边删除;
    • 定义map,key:连通块,value:连通块大小;
    • 定义最大连通块大小max;
    • 如果当前最大连通块大小比之前的最小值还小,则更新最小值和最小值所在的城市;
    • 如果当前最大连通块大小与之前的最小值相等,则将城市加入最小值所在的城市列表;
  6. 输出最小的最大连通块所在的城市。

五、Java算法源码

package com.guor.od;

import java.util.*;

public class OdTest {
    static class FindUnionSet {
        // 存储每个节点的父节点
        private int[] fatherArr;

        // 初始化并查集,每个节点的父节点为自己
        public FindUnionSet(int n) {
            fatherArr = new int[n];
            for (int i = 0; i < n; i++) fatherArr[i] = i;
        }

        // 查找x的祖先节点,路径压缩优化
        public int find(int x) {
            if (fatherArr[x] != x) {
                fatherArr[x] = find(fatherArr[x]);
            }
            return fatherArr[x];
        }

        // 合并x和y所在的集合
        public void unionSet(int x, int y) {
            int x_father = find(x);
            int y_father = find(y);

            // 如果x和y不在同一个集合中,则将y的祖先节点设为x的祖先节点
            if (x_father != y_father) {
                fatherArr[y_father] = x_father;
            }
        }
    }

    public static void main(String[] args) throws Exception {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();

        // 存储n-1条关系
        int[][] relationArrs = new int[n - 1][2];
        // 输入n-1条关系
        for (int i = 0; i < n - 1; i++) {
            relationArrs[i][0] = sc.nextInt();
            relationArrs[i][1] = sc.nextInt();
        }

        // 最小的最大连通块大小
        int min = Integer.MAX_VALUE;
        // 最小的最大连通块所在的城市
        List<Integer> cityList = new ArrayList<>();

        // 枚举每个城市作为特殊城市
        for (int i = 1; i <= n; i++) {
            // 初始化并查集
            FindUnionSet fus = new FindUnionSet(n + 1);
            // 将与特殊城市相连的边删除
            for (int[] relationArr : relationArrs) {
                int x = relationArr[0];
                int y = relationArr[1];
                if (x == i || y == i) {
                    continue;
                }
                fus.unionSet(x, y);
            }

            // key:连通块
            // value:连通块大小
            Map<Integer, Integer> map = new HashMap<>();
            for (int father : fus.fatherArr) {
                father = fus.find(father);
                map.put(father, map.getOrDefault(father, 0) + 1);
            }

            // 最大连通块大小
            int max = 0;
            for (Map.Entry<Integer, Integer> entry : map.entrySet()) {
                max = Math.max(max, entry.getValue());
            }

            // 如果当前最大连通块大小比之前的最小值还小,则更新最小值和最小值所在的城市
            if (max < min) {
                min = max;
                cityList.clear();
                cityList.add(i);
                // 如果当前最大连通块大小与之前的最小值相等,则将城市加入最小值所在的城市列表
            } else if (max == min) {
                cityList.add(i);
            }
        }

        // 输出最小的最大连通块所在的城市
        for (int city : cityList) {
            System.out.print(city + " ");
        }
    }
}

六、效果展示

1、输入

5
1 2
2 3
3 4
4 5

2、输出

3

3、说明

对于城市3,切断通往3的所有道路后,形成2个城市群[(1,2),(4,5)],其聚集度分别都是2,。DP3 = 2。
对于城市4,切断通往城市4的所有道路后,形成2个城市群[(1,2,3),(5)],DP4 = max(3,1) = 3。
以此类推,切断其他城市的所有道路后,得到的DP都会大于2,因为城市3就是满足条件的城市,输出是3。

在这里插入图片描述


🏆下一篇:华为OD机试真题 Java 实现【路灯照明问题】【2022Q4 100分】,感谢fly晨发现这个问题,并提供更优质的算法

🏆本文收录于,华为OD机试(JAVA)真题(A卷+B卷)

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/863746.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux网络服务之DNS域名解析

重要的DNS域名解析 一、DNS概述1.1 DNS简介1.2 本地hosts文件1.3 DNS架构1.4 查询方式 二、DNS域名解析原理2.1 解析类型2.2 原理详解2.3 举例 三、bind服务端程序3.1 什么是bind&#xff1f;3.2 配置文件详解3.2.1 主配置文件概述及内容主要格式3.2.2 域名文件概述及内容主要格…

leetcode118. 119.杨辉三角

118 题目&#xff1a; 给定一个非负整数 numRows&#xff0c;生成「杨辉三角」的前 numRows 行。 在「杨辉三角」中&#xff0c;每个数是它左上方和右上方的数的和。 思路&#xff1a; 可以发现从第三行开始&#xff0c;从第二个元素到倒数第二个元素&#xff0c;每个元素都…

电视盒子什么品牌好?实测20天后分享电视盒子推荐

电视盒子可以让老旧电视机重生&#xff0c;解决卡顿、资源少等问题&#xff0c;只需要联网就能观看海量视频资源。不过对于电视盒子如何选购很多人并不了解&#xff0c;我通过对比十几款主流电视盒子后整理了这份电视盒子推荐清单&#xff0c;跟着我一起看看电视盒子什么品牌好…

记一件异常访问记录

一、问题描述 某安全护网期间&#xff0c;web日志中大量出现异常账户请求&#xff0c;虽然报404错误&#xff0c;但是不同异常账号的连续尝试在特殊时期&#xff0c;还是令人担忧. 进程如下&#xff1a;/usr/bin/python2 -Es /usr/sbin/tuned -l -P 二、处理及说明 1&#x…

涛思数据联合长虹佳华、阿里云 Marketplace 正式发布 TDengine Cloud

近日&#xff0c;涛思数据联合长虹佳华&#xff0c;正式在阿里云 Marketplace 发布全托管的时序数据云平台 TDengine Cloud&#xff0c;为用户提供更加丰富的订购渠道。目前用户可通过阿里云 Marketplace 轻松实现 TDengine Cloud 的订阅与部署&#xff0c;以最低的成本搭建最高…

跨境多语言商城源码搭建--定制代码+源码开源

搭建一个跨境多语言商城需要以下步骤&#xff1a; 1. 确定需求&#xff1a;首先&#xff0c;需要明确商城的功能和需求&#xff0c;比如支持哪些语言、支持哪些支付方式、支持哪些货币等。根据需求来决定使用的开发语言和技术栈。 2. 寻找源码&#xff1a;可以在互联网上搜索…

赛码网-上台阶(dp) 100%AC代码(C)

———————————————————————————————————— ⏩ 大家好哇&#xff01;我是小光&#xff0c;嵌入式爱好者&#xff0c;一个想要成为系统架构师的大三学生。 ⏩最近在准备秋招&#xff0c;一直在练习编程。 ⏩本篇文章对赛码网的上台阶 题目做一个…

【Pytorch:nn.Embedding】简介以及使用方法:用于生成固定数量的具有指定维度的嵌入向量embedding vector

文章目录 1、nn.Embedding2、使用场景 1、nn.Embedding 首先我们讲解一下关于嵌入向量embedding vector的概念 1&#xff09;在自然语言处理NLP领域&#xff0c;是将单词、短语或其他文本单位映射到一个固定长度的实数向量空间中。嵌入向量具有较低的维度&#xff0c;通常在几…

医院国际医疗中心智能化系统规划设计方案[81页PPT]

导读&#xff1a;原文《医院国际医疗中心智能化系统规划设计方案[81页PPT]》&#xff08;获取来源见文尾&#xff09;&#xff0c;本文精选其中精华及架构部分&#xff0c;逻辑清晰、内容完整&#xff0c;为快速形成售前方案提供参考。 完整版领取方式 完整版领取方式&#xff…

如何对分布式光伏发电站进行智能化监测?安科瑞 顾语欢

—、概述 随着“双碳”目标提出及逐步落实&#xff0c;本就呈现出较好发展势头的分布式光伏发展有望大幅提速。“双碳”目标意味 着国家产业结构的调整&#xff0c;未来10年&#xff0c;新能源装机将保持在110GW以上的年增速&#xff0c;这里面包含集中式光伏电站和分布式光伏…

02 - git 文件重命名

第一种方式&#xff1a; mv kongfu_person.txt kongfu.txt git add .第二种方式&#xff1a; git mv kongfu_person.txt kongfu.txt

Baklib: 逆袭语雀的在线帮助中心,知识库管理工具

1. 介绍 在现代的技术发展中&#xff0c;知识管理变得越来越重要。特别是对于企业来说&#xff0c;拥有一个高效的知识库管理工具可以极大地提高工作效率和团队合作。Baklib就是这样一款在线帮助中心和知识库管理工具&#xff0c;它可以帮助企业集中管理和共享知识&#xff0c…

红帽8.2版本CSA题库:第七题配置 NTP

红帽8.2版本CSA题库&#xff1a;第七题配置 NTP systemctl status chronyd &#xff03;查看状态 yum -y install chrony &#xff03;如果没有安装&#xff0c;就安装一下 vim /etc/chrony.conf server materials.example.com iburst :wq syste…

MySQL缓存策略

文章目录 一、MySQL缓存方案的作用二、提高MySQL访问性能的方式2.1 读写分离2.1.1 是什么&#xff1f;2.1.2 解决了什么&#xff1f;2.1.3 原理是什么&#xff1f; 2.2 连接池2.1.1 是什么&#xff1f;2.1.2 解决了什么&#xff1f;2.1.3 原理是什么&#xff1f; 2.3 异步连接2…

【论文阅读】NoDoze:使用自动来源分类对抗威胁警报疲劳(NDSS-2019)

NODOZE: Combatting Threat Alert Fatigue with Automated Provenance Triage 伊利诺伊大学芝加哥分校 Hassan W U, Guo S, Li D, et al. Nodoze: Combatting threat alert fatigue with automated provenance triage[C]//network and distributed systems security symposium.…

Arcgis中直接通过sde更新sqlserver空间数据库失败

问题 背景 不知道有没有人经历过这样一个情况,我们直接在Arcgis中通过sde更新serserver数据库会失败,就是虽然在sde更新sqlserver数据库,但是在Navicat中通过sql语句来查询,发现数据并没有更新,如:上图中,更新数据库后,第一张图是sde打开的sqlserver数据库,它的数据库…

自动测试框架airtest应用一:将XX读书书籍保存为PDF

一、Airtest的简介 Airtest是网易出品的一款基于图像识别和poco控件识别的一款UI自动化测试工具。Airtest的框架是网易团队自己开发的一个图像识别框架&#xff0c;这个框架的祖宗就是一种新颖的图形脚本语言Sikuli。Sikuli这个框架的原理是这样的&#xff0c;计算机用户不需要…

24届近5年南京工业大学自动化考研院校分析

今天给大家带来的是南京工业大学控制考研分析 满满干货&#xff5e;还不快快点赞收藏 一、南京工业大学 学校简介 南京工业大学&#xff08;Nanjing Tech University&#xff09;&#xff0c;简称“南工”&#xff0c;位于江苏省南京市&#xff0c;由国家国防科技工业局、住…

宿舍管理系统--前后端分离式项目架构流程复盘(三万字详解)

文章目录 &#x1f412;个人主页&#x1f3c5;JavaEE系列专栏&#x1f4d6;前言&#xff1a;【&#x1f387;前端】先创建Vue-cli项目&#xff08;版本2.6.10&#xff0c;仅包含babel&#xff09;&#xff0c;请选择此项目并创建 【整理简化项目模板】【&#x1f380;创建路由】…