算法Day31 房间收纳

房间收纳

Description

对于零落的玩具,你需要进行收纳,为了将最多的玩具进行收纳,请你合理分配收纳柜和房间数量。
请你将一些玩具收纳在一个房间中,给你一个二维数组 roomTypes,其中的roomTypes[i] = {numberOfBoxes_i, numberOfUnitPerRoom_i}

  • numberOfBoxes_i 是类型 i 的收纳柜的数量;
  • numberOfUnitPerRoom_i 是类型 i 的收纳柜可以收纳的玩具数量;
    整数roomSize表示房间中可以放下的收纳柜的最大数量。只要箱子数量不超过 roomSize,你就可以选择任意收纳柜放到房间中。
    返回房间可以收纳的玩具最大总数。

提示:
(1)1 ≤ roomTypes.length ≤ 1000
(2)1 ≤ numberOfBoxes_i, numberOfUnitPerRoom_i ≤ 1000
(3)1 ≤ roomSize ≤ 10^6

Input

第 1 行输入收纳柜种类数目 n;
第 2 到第 n+1 行输入第 i 个收纳柜的数量及当前收纳柜可以收纳的玩具数量(即二维数组 roomTypes),每行两个数之间用空格隔开;
第 n+2 行输入房间可以放下的收纳柜总数量;
如:
3
1 3
2 2
6 1
4

Output

输出最大收纳的玩具数量(整数),如:
7

Sample

在这里插入图片描述

代码

import java.util.Scanner;public class Main{public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int  n = scanner.nextInt();int roomN[] = new int[n];int roomC[] = new int[n];for(int i = 0;i<n;i++){roomN[i] = scanner.nextInt();roomC[i] = scanner.nextInt();}int capacity = scanner.nextInt();//排序for(int i = 0;i<n-1;i++)for(int j = i+1;j<n;j++){if(roomC[i]<roomC[j]){int tempN = roomN[i];roomN[i] = roomN[j];roomN[j] = tempN;int tempC = roomC[i];roomC[i] = roomC[j];roomC[j] = tempC;}}//收纳的玩具数量int count = 0;//开始计数的序号int number=0;//容量int c = 0;while(c<capacity&&number<n){if(roomN[number]>0){count+=roomC[number];c++;roomN[number]--;}else {number++;}}System.out.println(count);}
}

思路

贪心法解决,首先排序,排序的时候两个数组同时交换
其次不断添加roomC即可

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

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

相关文章

Narak

靶场下载 https://download.vulnhub.com/ha/narak.ova 信息收集 # nmap -sn 192.168.1.0/24 -oN live.nmap Starting Nmap 7.94 ( https://nmap.org ) at 2023-12-09 22:18 CST Nmap scan report for 192.168.1.1 (192.168.1.1) Host is up (0.…

【模型训练】声音克隆

【模型训练】声音克隆

AI智能视界,视频监控技术的革新与突破

智能视频监控概述 TSINGSEE青犀智能监控系统是通过摄像头采集视频数据&#xff0c;经过压缩技术处理后传输至服务器&#xff0c;再由服务器进行存储和管理并汇聚到EasyCVR视频融合平台之中&#xff0c;进行统一的分发处理。采用先进的视频压缩技术&#xff0c;确保视频质量&am…

锂电池基础知识及管理方式总结

这两天在排查一个锂电池无法充电的问题&#xff0c;用的是电池管理芯片BQ25713&#xff0c;网上相关的资料也很少&#xff0c;查看数据手册时&#xff0c;里面也有很多术语参数等不是很理解&#xff0c;所以&#xff0c;在此对锂电池的基础知识做个简单的总结&#xff0c;方面后…

react中的setState是同步还是异步

setState 只在合成事件和钩子函数中是“异步”的&#xff0c;在原生事件和 setTimeout 中都是同步的。 合成事件&#xff1a;就是react 在组件中的onClick等都是属于它自定义的合成事件 原生事件&#xff1a;比如通过addeventListener添加的&#xff0c;dom中的原生事件 setS…

如何通过控制台排查定位EasyCore?

过去当数据库出现了问题&#xff0c;我们只能通过日志去查看问题&#xff0c;可能是数据库有了重启、主节点发生了漂移或查询语句太复杂&#xff0c;这一整套逻辑走下来只能winsen, karel。 我们经常说数据库负载过高&#xff0c;请求很多&#xff0c;但我们却不能直接告诉哪个…

python常见代码用法

1.result [[]] * n 和 result [[] for _ in range(n)] 辨析 n 3 result [[]] * nprint(result) # 输出&#xff1a;[[], # [], # []]print(result[0] is result[1] is result[2]) # 输出&#xff1a;True* 运算符进行复制&#xff0c;这些空列表实际…

MacOS系统使用ESP8266(CP2102)开发板

开发板实物 连接开发板到macos 终端输入lsusb查看,开发板硬件成功识别 打开Arduino IDE并选择开发板 开发板连接成功 编译代码 上传成功 打开串口监视器,按一下RST键,可看到WIFI名输出及WIFI的IP输出 WIFI热点功能启用

Ray使用备注

Ray使用备注 框架介绍 Ray是一种python分布式任务调度框架其支持 无状态的任务并发执行,也支持 有状态的任务按照一定顺序执行其支持 分布式调度器,在一个节点上创建的任务先给本节点的局部调度器,并让本节点自己处理,当资源不够时,再将任务发给全局调度器供其他节点处理其支…

Python 自动化之修理PDF文件(二)

PDF文件_合并与拆分PDF文档Pro版本 文章目录 PDF文件_合并与拆分PDF文档Pro版本前言一、要做成什么样子二、主要用到的函数三、基本思路1.引入库2.创建用户输入模块3.确定主框架 四、文档合并代码模块1.用户输入和函数调用2.引导用户输入文档信息3.合并文档内容4.命名新文档生成…

CMake 构建指南:如何提高 C-C++ 项目的可维护性

如果您是一位 C/C 开发人员&#xff0c;那么您一定知道在编写和维护大型项目时所面临的挑战。这些项目通常包含大量的源代码、库和依赖项&#xff0c;需要耗费大量的时间和精力才能构建和维护。在这种情况下&#xff0c;使用自动化工具可以大大减轻您的负担&#xff0c;提高项目…

传输层协议:TCP协议和UDP协议

文章目录 传输层协议&#xff1a;TCP协议和UDP协议一、TCP协议介绍&#xff08;面向连接&#xff0c;稳定&#xff0c;慢&#xff09;1、TCP特性2、TCP报文格式3、TCP三次握手4、TCP四次挥手5、常用的TCP端口号及其功能 二、UDP协议介绍&#xff08;无连接&#xff0c;不稳定&a…

【ET8】4.ET8入门-ECS解析

ECS ECS组件生命周期 参考连接 ⼀种类ECS设计范式的介绍 3.3一切皆实体 4.1组件式设计 【ET框架课程】04-Entity&Component&System_哔哩哔哩_bilibili 【ET框架课程】05-ECS组件生命周期_哔哩哔哩_bilibili

深度学习学习顺序梳理

https://www.bilibili.com/video/BV1to4y1G7xq/?spm_id_from333.999.0.0&vd_source9607a6d9d829b667f8f0ccaaaa142fcb 1.吴恩达机器学习课程 已学完&#xff0c;时间较久了&#xff0c;后续可以重新听一遍&#xff0c;整理一下笔记 2. 白板推导读西瓜书 统计学习方法看…

GitHub入门命令介绍

GitHub是当今最受欢迎的代码托管平台之一&#xff0c;它提供了强大的版本控制和协作功能。 对于初学者来说&#xff0c;熟悉GitHub的基本命令非常重要。下面介绍一些常用的GitHub命令。 一、安装Git 1. Windows系统&#xff1a;在Windows上使用GitHub之前&#xff0c;您需要先…

FS基础概念

verto webrtc的信令 1000-1019 默认20个用户 密码1234 健全用户名和用户用户名一样都是1000 cd FS make samples 执行后会在/usr/local/下建立freeswitch目录,并且只会放入conf htdocs和这两个目录下的所有文档,并且不会编译出freeswitch和fs_cli。 /usr/local/freeswitch/b…

选择流量回溯分析系统的关键因素

在网络安全和性能优化的背景下&#xff0c;选择适用的流量回溯分析系统变得至关重要。这些系统帮助组织深入了解网络流量&#xff0c;追踪异常行为&#xff0c;并提供关键的信息以加强网络安全。本文将介绍选择流量回溯分析系统时需要考虑的关键因素&#xff0c;以帮助组织做出…

微信小程序、uniapp仿网易云UImusic播放器(附源码)

一、uni-app框架介绍 1.什么是 uni-app uni-app 是一个使用vue的语法 微信小程序的标签和API的跨平台前端框架&#xff0c;开发者编写一套代码&#xff0c;可编译到iOS、Android、H5、小程序等多个平台&#xff0c;几乎覆盖所有流量端。 uni-app 具有跨端数量更多、性能体验…

Python去除字符串中空格(删除指定字符)的3种方法

str 提供了如下常用的方法来删除空白&#xff1a; strip()&#xff1a;删除字符串前后的空白。 lstrip()&#xff1a;删除字符串前面&#xff08;左边&#xff09;的空白。 rstrip()&#xff1a;删除字符串后面&#xff08;右边&#xff09;的空白。 需要说明的是&#xff…

【数据结构】贪心算法

一.贪心算法的定义 贪心算法是指在对问题求解时&#xff0c;总是做出在当前看来是最好的选择。也就是说&#xff0c;不从整体最优上加以考虑&#xff0c;只做出在某种意义上的局部最优解。 贪心算法的结果是最优解的最好近似。 优点&#xff1a;简单&#xff0c;高效。 缺点&…