#OD353. 机器人仓库搬砖

题目描述

机器人搬砖,一共有 N 堆砖存放在 N 个不同的仓库中,第 i 堆砖中有 bricks[i] 块砖头,要求在 8 小时内搬完。

机器人每小时能搬砖的数量取决于有多少能量格,机器人一个小时中只能在一个仓库中搬砖,机器人的能量格只在这一个小时有效,为使得机器人损耗最小化,应尽量减小每次补充的能量格数。

为了保障在 8 小时内能完成搬砖任务,请计算每小时给机器人充能的最小能量格数。

  • 无需考虑机器人补充能力格的耗时;
  • 无需考虑机器人搬砖的耗时;
  • 机器人每小时补充能量格只在这一个小时中有效;

输入描述

第一行为一行数字,空格分隔

输出描述

机器人每小时最少需要充的能量格,若无法完成任务,输出 -1

用例1

输入

复制代码
30 12 25 8 19

Copy

输出

复制代码
15

Copy

用例2

输入

复制代码
10 12 25 8 19 8 6 4 17 19 20 30

Copy

输出

复制代码
-1

Copy

说明

砖的堆数为12堆存放在12个仓库中,机器人一个小时内只能在一个仓库搬砖,不可能完成任务。

cpp 复制代码
#include <algorithm>
#include <string>
#include <iostream>
#include <sstream>
#include <vector>
using namespace std;

int main() {
	int a = 0;
	vector<int> vec;
	while (cin >> a)
	{
		vec.push_back(a);
		if (cin.peek() == '\n')
			break;
	}

	if (vec.size() > 8) {
		cout << -1 << endl;
		return 0;
	}
	int max = *max_element(vec.begin(), vec.end());
	if (vec.size() == 8) {
		cout << max << endl;
		return 0;
	}
	//二分法
	int min = 1;
	int midd = (max + min) / 2;
	int result = max;
	while (min < max)
	{
		int count = 0;
		for (int val : vec)
		{
			count += val / midd;
			if (val % midd > 0) {
				count++;
			}
		}
		if (count <= 8){
			max--;
			result = std::min(result, midd);
		}
		else {
			min++;
		}
		midd = (max + min) / 2;
	}

	cout << result << endl;
	return 0;
}

测评通过率100%。

有一个地方可以优化:前后两次循环midd可能会存在相等的情况,可以加上判断,相等的话就继续执行max-- 或min-- .

相关推荐
沫儿笙3 小时前
CLOOS克鲁斯焊接机器人混合气节气装置
人工智能·机器人
Deepoch3 小时前
从“机械臂”到“农艺手”:Deepoc如何让机器人理解果实的生命语言
人工智能·机器人·采摘机器人·农业机器人·具身模型·deepoc
思绪漂移3 小时前
算法调度:场景分析、策略与工程化技术难点——无人机全量感知 vs 机器人定点路由
机器人·无人机·算法调度
才兄说3 小时前
机器人租赁服务中的不确定性:客户视角下的支持体验差异
机器人
无限码力4 小时前
华为OD技术面真题 - 计算机网络 - 3
计算机网络·华为od·面试·华为od技术面真题·华为od面试八股文·华为od技术面计算机网络相关
益莱储中国5 小时前
2026 CES 聚焦 Physical AI:AI 硬件、具身智能、自动驾驶、芯片战争、机器人、显示技术等全面爆发
人工智能·机器人·自动驾驶
甄心爱学习5 小时前
机器人算法与设计-复习
人工智能·机器人
Deepoch17 小时前
赋能未来:Deepoc具身模型开发板如何成为机器人创新的“基石”
人工智能·机器人·开发板·具身模型·deepoc
应用市场20 小时前
自动送餐机器人技术全解析——从路径规划到任务调度
机器人
小烤箱21 小时前
Autoware Universe 感知模块详解 | 第十一节:检测管线的通用工程模板与拆解思路导引
人工智能·机器人·自动驾驶·autoware·感知算法