华为OD-D卷精准核酸检测

为了达到新冠疫情精准防控的需要,为了避免全员核酸检测带来的浪费,需要精准圈定可能被感染的人群。

现在根据传染病流调以及大数据分析,得到了每个人之间在时间、空间上是否存在轨迹的交叉。

现在给定一组确诊人员编号(X1, X2, X3, .... Xn),在所有人当中,找出哪些人需要进行核酸检测,输出需要进行核酸检测的人数。(注意:确诊病例自身不需要再做核酸检测)

需要进行核酸检测的人,是病毒传播链条上的所有人员,即有可能通过确诊病例所能传播到的所有人。

例如:A是确诊病例,A和B有接触、B和C有接触、C和D有接触、D和E有接触,那么B\C\D\E都是需要进行核酸检测的人。

输入描述:

第一行为总人数N

第二行为确诊病例人员编号(确诊病例人员数量<N),用逗号分割

第三行开始,为一个N*N的矩阵,表示每个人员之间是否有接触,0表示没有接触,1表示有接触。

输出描述:

整数:需要做核酸检测的人数

备注:

人员编号从0开始

0<N<100

题目解析:其实就是循环的去遍历确诊病例找到接触的人员,然后把接触人员也遍历下继续找就行,唯一需要注意的是,遍历的过程可能遇到重复的接触人员,最好通过set进行去重就好了,最后返回set的大小,记得返回的目标值要减去确诊人员数量。

java 复制代码
import java.util.*;

public class Main {
    public static void main(String[] args) {
//        int n = 5;
//        int[] target = new int[]{1, 2};
//        int[][] nums = new int[][]{{1, 1, 0, 1, 0}, {1, 1, 0, 0, 0}, {0, 0, 1, 0, 1}, {1, 0, 0, 1, 0}, {0, 0, 1, 0, 1}};
        // 处理数据
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();

        String[] string1 = scanner.next().split(",");
        int[] target = new int[string1.length];
        for (int i = 0; i < target.length; i++) {
            target[i] = Integer.parseInt(string1[i]);
        }
        int[][] nums = new int[n][n];
        for (int i = 0; i < n; i++) {
            String[] string = scanner.next().split(",");
            for (int j = 0; j < n; j++) {
                nums[i][j] = Integer.parseInt(string[j]);
            }
        }
        // stack用于存储确诊人员和接触人员,依次从里面找
        Stack<Integer> stack = new Stack();
        // set进行去重,避免死循环
        HashSet<Integer> set = new HashSet<>();
        for (int i = 0; i < target.length; i++) {
            set.add(target[i]);
            stack.push(target[i]);
        }
        while (!stack.isEmpty()) {
            Integer pop = stack.pop();
            // 两个for循环判断是否存在秘接人员,注意set去重
            for (int i = 0; i < n; i++) {
                if (nums[i][pop] != 1 || set.contains(i)) {
                    continue;
                }
                stack.add(i);
                set.add(i);
            }
            for (int i = 0; i < n; i++) {
                if (nums[pop][i] != 1 || set.contains(i)) {
                    continue;
                }
                stack.add(i);
                set.add(i);
            }
        }
        System.out.println(set.size() - target.length);
    }
}
相关推荐
一只码代码的章鱼1 小时前
粒子群算法 笔记 数学建模
笔记·算法·数学建模·逻辑回归
小小小小关同学1 小时前
【JVM】垃圾收集器详解
java·jvm·算法
圆圆滚滚小企鹅。1 小时前
刷题笔记 贪心算法-1 贪心算法理论基础
笔记·算法·leetcode·贪心算法
Kacey Huang1 小时前
YOLOv1、YOLOv2、YOLOv3目标检测算法原理与实战第十三天|YOLOv3实战、安装Typora
人工智能·算法·yolo·目标检测·计算机视觉
eguid_12 小时前
JavaScript图像处理,常用图像边缘检测算法简单介绍说明
javascript·图像处理·算法·计算机视觉
带多刺的玫瑰2 小时前
Leecode刷题C语言之收集所有金币可获得的最大积分
算法·深度优先
LabVIEW开发2 小时前
PID控制的优势与LabVIEW应用
算法·labview
涅槃寂雨2 小时前
C语言小任务——寻找水仙花数
c语言·数据结构·算法
就爱学编程3 小时前
从C语言看数据结构和算法:复杂度决定性能
c语言·数据结构·算法
刀客1233 小时前
数据结构与算法再探(六)动态规划
算法·动态规划