【二分做题笔记】组装玩具

描述

小华打算用 n 种(编号为 1 到 n)材料组装玩具。其中第 i 种材料的数量为 Xi 个。组装一个玩具需要第 i 种材料 Yi 个。小华另外有 m 个万能材料,每个万能材料可以作为 n 种材料中的任意一个材料使用。

请编程计算小华最多可以组装多少个玩具?

输入

输入共3行。

第1行两个整数n和m,分别表示小华有n种材料和m个万能材料。第2行n个正整数,其中第i个整数Xi表示小华第i种材料有Xi个。

第3行n个正整数,其中第i个整数Yi表示小华组装一个玩具需要第i种材料Yi个。

输出

输出共 1 行。

一个整数,表示小华最多可以组装多少个玩具。

输入/输出例子1

输入:

3 1

13 7 20

3 2 5

输出:

4

样例解释

50%的测试点输入数据保证1≤n≤1000, 1≤m≤10 ^ 4,1≤Xi, Yi≤10 ^ 4。

100%的测试点输入数据保证1≤n≤100000, 1≤m≤10 ^ 9,1≤Xi, Yi≤10 ^ 9。

做题心得

这道题可以枚举小华最多做xx个玩具,然后写一个函数判断做xx个玩具是否成立。判断函数如下:

cpp 复制代码
bool pd(ll xx){
	ll mm = m; 
	for(int i=1;i<=n;i++){
		ll hc = x[i]/y[i];
		if(hc<xx){
			ll need=(xx-hc)*y[i]-(x[i]-hc*y[i]);
			if(need>mm) return 0;
			else mm-=need;
		}
	}
	return 1;
} 

从判断函数可以看出时间复杂度是O(n),而数据规模为10的5次方。所以枚举xx时可以用二分算法不超时。l初始化为0,l的值是可以做答案的,r的值比答案大。这里有一个坑:如何确定r呢?我一开始就找x[i]/y[i]的最大值+1,其实还是小了。比如,现在有2种材料,每种有10000个,万能材料有10000个,合成一个玩具需要每种材料各1个的情况,如果r = max{ x[i] / y[i] } +1,那么最多就是10001个,实际上完成材料还可以继续用,最多应该能合成15000的。所以,我把r初始化为max{x[i]/y[i]}+m。

AC代码

cpp 复制代码
#include<bits/stdc++.h>
#define ll long long
using namespace std;
ll n,m,x[100005],y[100005]; 
bool pd(ll xx){
	ll mm = m; 
	for(int i=1;i<=n;i++){
		ll hc = x[i]/y[i];
		if(hc<xx){
			ll need=(xx-hc)*y[i]-(x[i]-hc*y[i]);
			if(need>mm) return 0;
			else mm-=need;
		}
	}
	return 1;
} 
int main(){
	ll mx=0; 
	cin>>n>>m;
	for(int i=1;i<=n;i++) cin>>x[i];
	for(int i=1;i<=n;i++) {
		cin>>y[i];
		mx = max(mx,x[i]/y[i]);	
	}
	ll l=0,r=mx+m;
	while(l+1<r){
		ll mid=(l+r)/2;
		if(pd(mid)) l=mid;
		else r=mid;
	}
	cout<<l;
    return 0;
}
相关推荐
wuweijianlove4 小时前
算法性能的渐近与非渐近行为对比的技术4
算法
一定要AK4 小时前
Spring 入门核心笔记
java·笔记·spring
_dindong4 小时前
cf1091div2 C.Grid Covering(数论)
c++·算法
AI成长日志4 小时前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
黎阳之光5 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
skywalker_115 小时前
力扣hot100-3(最长连续序列),4(移动零)
数据结构·算法·leetcode
6Hzlia5 小时前
【Hot 100 刷题计划】 LeetCode 17. 电话号码的字母组合 | C++ 回溯算法经典模板
c++·算法·leetcode
_李小白5 小时前
【OSG学习笔记】Day 38: TextureVisitor(纹理访问器)
android·笔记·学习
wfbcg5 小时前
每日算法练习:LeetCode 209. 长度最小的子数组 ✅
算法·leetcode·职场和发展
_日拱一卒5 小时前
LeetCode:除了自身以外数组的乘积
数据结构·算法·leetcode