蓝桥杯2020年第十一届JavaB组真题题目+解析+代码+答案:3.合并检测

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 蓝桥杯2020年第十一届JavaB组真题题目+解析+代码+答案:3.合并检测

问题描述:

新冠疫情由新冠病毒引起,最近在 A 国蔓延,为了尽快控制疫情,

A 国准 备给大量民众进病毒核酸检测。然而,用于检测的试剂盒紧缺。

为了解决这一困难,科学家想了一个办法:合并检测。

即将从多个人(k 个)采集的标本放到同一个试剂盒中进行检测。

如果结果为阴性,则说明这 k 个人都是阴性,用一个试剂盒完成了 k 个人的检测。

如果结果为阳性,则说明 至少有一个人为阳性,

需要将这 k 个人的样本全部重新独立检测(从理论上看,

如果检测前 k−1 个人都是阴性可以推断出第 k 个人是阳性,

但是在实际操作中 不会利用此推断,而是将 k 个人独立检测),

加上最开始的合并检测,一共使用 了 k + 1 个试剂盒完成了 k 个人的检测。

A 国估计被测的民众的感染率大概是 1%,呈均匀分布。

请问 k 取多少能 最节省试剂盒?

这是一道结果填空题,你只需要算出结果后提交即可。

本题的结果为一个 整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

解题思路:

> 我们假设总共有100人,那么患者为1人
> 1. 如果k为10,那么可以分为10组,也就是需要10个试剂,但当检查到有患者的一组时,需要对这组每个人再分别进行一次检测,也就是说还需要10个试剂,总共试剂就为10+10=20
> 2. 如果k为33,那么可以分为4组,33+33+33+1,也就是需要100 / k个试剂+1,当检查到有患者的一组时,需要对每个人进行检测,就是再需要33个试剂
> 
> 所以我们可以推出公式,如果k可以整除100,那么需要总试剂就为100 / k + k
> 如果不能够整除,那么就为 100 / k + 1 + k

代码:

public class Main {
    public static void main(String[] args) throws ParseException {
      int min=0;
      int sum=Integer.MAX_VALUE;
      for(int i=1;i<=100;i++) {
        if(100%i==0) {
          if(100/i+i<sum) {
            sum=100/i+i;
            min=i;
          }
        }
        else {
          if(100/i+1+i<sum) {
            sum=100/i+1+i;
            min=i;
          }
        }
      }
      System.out.println(min);
  }
}

答案:

10


目录
相关文章
|
13天前
|
PHP 开发者 容器
PHP命名空间深度解析:避免命名冲突与提升代码组织####
本文深入探讨了PHP中命名空间的概念、用途及最佳实践,揭示其在解决全局命名冲突、提高代码可维护性方面的重要性。通过生动实例和详尽分析,本文将帮助开发者有效利用命名空间来优化大型项目结构,确保代码的清晰与高效。 ####
17 1
|
21天前
|
机器学习/深度学习 存储 人工智能
强化学习与深度强化学习:深入解析与代码实现
本书《强化学习与深度强化学习:深入解析与代码实现》系统地介绍了强化学习的基本概念、经典算法及其在深度学习框架下的应用。从强化学习的基础理论出发,逐步深入到Q学习、SARSA等经典算法,再到DQN、Actor-Critic等深度强化学习方法,结合Python代码示例,帮助读者理解并实践这些先进的算法。书中还探讨了强化学习在无人驾驶、游戏AI等领域的应用及面临的挑战,为读者提供了丰富的理论知识和实战经验。
46 5
|
1月前
|
JSON JavaScript 前端开发
蓝桥杯web组赛题解析和杯赛技巧
本文作者是一位自学前端两年半的大一学生,在第十五届蓝桥杯Web组比赛中获得省一和国三。文章详细解析了比赛题纲,涵盖HTML、CSS、JavaScript、Echarts和Vue等技术要点,并分享了备赛技巧和比赛经验。作者强调了多写代码和解题思路的重要性,同时提供了省赛和国赛的具体流程及注意事项。希望对参赛者有所帮助。
69 3
|
1月前
|
存储 安全 Java
系统安全架构的深度解析与实践:Java代码实现
【11月更文挑战第1天】系统安全架构是保护信息系统免受各种威胁和攻击的关键。作为系统架构师,设计一套完善的系统安全架构不仅需要对各种安全威胁有深入理解,还需要熟练掌握各种安全技术和工具。
116 10
|
1月前
|
前端开发 JavaScript 开发者
揭秘前端高手的秘密武器:深度解析递归组件与动态组件的奥妙,让你代码效率翻倍!
【10月更文挑战第23天】在Web开发中,组件化已成为主流。本文深入探讨了递归组件与动态组件的概念、应用及实现方式。递归组件通过在组件内部调用自身,适用于处理层级结构数据,如菜单和树形控件。动态组件则根据数据变化动态切换组件显示,适用于不同业务逻辑下的组件展示。通过示例,展示了这两种组件的实现方法及其在实际开发中的应用价值。
36 1
|
2月前
|
机器学习/深度学习 人工智能 算法
揭开深度学习与传统机器学习的神秘面纱:从理论差异到实战代码详解两者间的选择与应用策略全面解析
【10月更文挑战第10天】本文探讨了深度学习与传统机器学习的区别,通过图像识别和语音处理等领域的应用案例,展示了深度学习在自动特征学习和处理大规模数据方面的优势。文中还提供了一个Python代码示例,使用TensorFlow构建多层感知器(MLP)并与Scikit-learn中的逻辑回归模型进行对比,进一步说明了两者的不同特点。
88 2
|
27天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
65 2
|
2月前
|
缓存 Java 程序员
Map - LinkedHashSet&Map源码解析
Map - LinkedHashSet&Map源码解析
73 0
|
2月前
|
算法 Java 容器
Map - HashSet & HashMap 源码解析
Map - HashSet & HashMap 源码解析
57 0
|
2月前
|
存储 Java C++
Collection-PriorityQueue源码解析
Collection-PriorityQueue源码解析
64 0

推荐镜像

更多