如何在华为OD机试B卷中获得满分?Java实现【食堂供餐】一文详解

news/2024/12/29 18:55:46/

请添加图片描述

✅创作者:陈书予
🎉个人主页:陈书予的个人主页
🍁陈书予的个人社区,欢迎你的加入: 陈书予的社区
🌟专栏地址: Java华为OD机试真题(2022&2023)

文章目录

  • 1. 题目描述
  • 2. 输入描述
  • 3. 输出描述
  • 4. Java算法源码
  • 5. 测试
  • 6.解题思路

1. 题目描述

某公司员工食堂以盒饭的方式供餐。

为将员工取餐排队时间降为0,食堂的供餐速度必须要足够快。

现在需要根据以往员工取餐的统计信息,计算出一个刚好能达到排队时间为0的最低供餐速度。

即,食堂在每个单位时间内必须至少做出多少份盒饭才能满足要求。

2. 输入描述

第一行输入一个正整数N,表示食堂开餐时长。

第二行为一个正整数M,表示开餐前食堂已经准备好的盒饭数量;

第三行为N个正整数,用空格分割,依次表示开餐时间内按时间顺序每个单位时间进入食堂取餐的人数。

3. 输出描述

一个整数,能满足题目要求的最低供餐速度。(每个单位时间需要做出多少份盒饭)。

补充说明
每人只能取一份盒饭。

需要满足排队时间为0,必须保证取餐员工到达食堂时,食堂库存盒饭数量不少于本次来取餐的人数。

第一个单位时间来取餐的员工只能取开餐前食堂准备好的盒饭。

每个单位时间里制作的盒饭只能供给后续单位时间来的取餐员工。食堂在每个单位时间里制作的盒饭数量是相同的。

4. Java算法源码

public static void main(String[] args) {Scanner in = new Scanner(System.in);// 食堂开餐时长int N = in.nextInt();// 开餐前食堂已经准备好的盒饭数量int M = in.nextInt();// 每个单位时间进入食堂取餐的人数int[] P = new int[N];// 总人数int count = 0;for (int i = 0; i < N; i++) {P[i] = in.nextInt();count += P[i];}// 最小出餐速度int left = 0;// 最大出餐速度 = 总人数 - 已经准备好的盒饭数量int right = count - M;while (left < right) {//二分法int mid = (left + right) / 2;// 是否还有剩余盒饭if (check(mid, M, N, P)) {right = mid;} else {left = mid + 1;}}// 最小出餐速度System.out.println(left);
}/*** 是否还有剩余盒饭* @param speed* @param M 已经准备好的盒饭数量* @param N 食堂开餐时长* @param P 每个单位时间进入食堂取餐的人数* @return*/
public static boolean check(int speed, int M, int N, int[] P) {boolean result = true;for (int i = 0; i < N; i++) {// 剩余盒饭数量 = 目前盒饭数量 - 每个时间段的取餐人数M -= P[i];// 如果盒饭不够了,返回falseif (M < 0) {result = false;break;}M += speed;}return result;
}

5. 测试

在这里插入图片描述

6.解题思路

  1. 采用二分法;
  2. left为最小出餐速度,right为最大出餐速度 = 总人数 - 已经准备好的盒饭数量;
  3. 判断是否还剩余盒饭;
  4. 如果盒饭不够了,返回false;
  5. 如果盒饭足够,则剩余盒饭数量 = 目前盒饭数量 - 每个时间段的取餐人数,再加上当前时间段生产的盒饭数量;

在这里插入图片描述


http://www.ppmy.cn/news/98340.html

相关文章

重学Ajax

概述 Ajax&#xff08;Asynchronous JavaScript And XML&#xff09;即异步 JavaScript 和 XML&#xff0c;是一组用于在网页上进行异步数据交换的Web开发技术&#xff0c;可以在不刷新整个页面的情况下向服务器发起请求并获取数据&#xff0c;然后将数据插入到网页中的某个位置…

基于STM32的定时器--定时中断(HAL库)

基于STM32的定时器--定时中断&#xff08;HAL库&#xff09; 介绍引言定时器介绍 实例项目介绍准备设计流程 介绍 引言 本文旨在介绍如何使用STM32CubeMX配置KEIL 5开发一个每10us定时器中断触发一次的项目。帮助初学者入门STM32的定时器使用。 定时器介绍 定时器是STM32微…

618京东预售一般便宜多少?跟直接买有啥区别?

618京东预售一般便宜多少?跟直接买有啥区别? 京东作为消费者比较喜欢的电商购物平台之一&#xff0c;经常会推出促销打折的活动&#xff0c;以吸引用户到平台上购物。在这些大促活动中&#xff0c;平台会在预售环节设置专属的优惠&#xff0c;让消费者下单提前锁定这些折扣&a…

vue2实例

目录 数据与方法 你提到vue有两种数据和方法&#xff0c;js是不是只有一种 vue2自带的实例和方法 vue2$会和jQuery冲突d的问题 vue2中被人吐槽的this&#xff08;vue3已改进&#xff09; 箭头函数和普通函数中的this 生命周期 数据与方法 没看懂&#xff0c;好像是讲在什…

Ansible原理简介与安装篇

工作原理 1、在Ansible管理体系中&#xff0c;存在“管理节点”和“被管理节点” 2、被管理节点通常被称为”资产“ 3、在管理节点上&#xff0c;Ansible将AdHoc或PlayBook转换为python脚本。并通过SSH将这些python脚本传递到被管理服务器上。在被管理服务器上依次执行&#xf…

SwiftUI中EnvironmentObject使用中,直接修改数据源的原值的方法

在Swift中有几种引用&#xff0c;一个通过Binding var Param来引用原变量的值&#xff0c;在子函数或子View中修改 Param&#xff0c;但我们也经常使用EnvironmentObject来引用全局数据。 例如&#xff1a; struct TestEnvSubView: View {EnvironmentObject var globalData :…

网络安全做红队攻防 35 岁以后可以干嘛?

35岁之后不是都当技术总监&#xff0c;CTO了或者自己创业了吗&#xff1f; 不会&#xff0c;单渗透测试来说&#xff0c;到后期更多是经验的积累。同一个事情&#xff0c;经验老道师傅的可能用更少的命令&#xff0c;发更少的请求完成这个事情&#xff0c;更隐蔽&#xff0c;更…

电动汽车变频器

目录 1、电动汽车与汽油动力车的区别 2、变频器 3、变频器内元件 3.1、汽车变频器的组成和功能 3.1.1、电容器 3.1.2、变频器控制单元 3.1.3、逆变桥驱动单元 3.1.4、逆变桥单元 3.2、汽车上变频器的组成和功能 3.2.1、DC/DC升压转换器。 3.2.2、DC/DC降压转换器。 …