蓝桥杯备战10.分巧克力

P8647 [蓝桥杯 2017 省 AB] 分巧克力 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

暴力枚举 过70%样例

cpp 复制代码
#include<bits/stdc++.h>
#define endl '\n'
#define int long long
using namespace std;
const int N = 2e7+10,M = 1e3+10;
int n,k;
int h[N],w[N];
bool check(int x)
{
	int cnt = 0;
	for(int i=1;i<=n;i++)
	{
		cnt+=(h[i]/x)*(w[i]/x);
	}
	if(cnt>=k)return true;
	else return false;
}
signed main()
{
	std::ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	cin>>n>>k;
	for(int i=1;i<=n;i++)cin>>h[i]>>w[i];
	int ans = 0;
	for(int i=1;i<=1e5;i++)
	{
		if(check(i))
		ans=i;
	}
	cout<<ans;
	return 0;
}

二分

cpp 复制代码
#include<bits/stdc++.h>
#define endl '\n'
#define int long long
using namespace std;
const int N = 2e7+10,M = 1e3+10;
int n,k;
int h[N],w[N];
bool check(int x)
{
	int cnt = 0;
	for(int i=1;i<=n;i++)
	{
		cnt+=(h[i]/x)*(w[i]/x);
	}
	if(cnt>=k)return true;
	else return false;
}
signed main()
{
	std::ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	cin>>n>>k;
	for(int i=1;i<=n;i++)cin>>h[i]>>w[i];
	int ans = -1;
	int l = 0,r = 1e5;
	while(l<r)
	{
		int mid = (l+r+1)/2;
		if(check(mid))
		{
			l = mid;
			ans = l;
		}
		else
		{
			r = mid-1;
			ans = r;
		}
	}
	cout<<ans;
	return 0;
}
相关推荐
零售ERP菜鸟29 分钟前
数字系统的新角色:从管控工具到赋能平台
大数据·人工智能·职场和发展·创业创新·学习方法·业界资讯
菜鸡儿齐2 小时前
leetcode-最小覆盖子串
算法·leetcode·职场和发展
我命由我123452 小时前
Photoshop - Photoshop 工具栏(60)污点修复工具
ui·adobe·职场和发展·求职招聘·职场发展·课程设计·photoshop
仰泳的熊猫3 小时前
题目1474:蓝桥杯基础练习VIP-阶乘计算
数据结构·c++·算法·蓝桥杯
闻缺陷则喜何志丹5 小时前
【状态压缩动态规划】P8733 [蓝桥杯 2020 国 C] 状态压缩动态规划|普及+
c++·算法·蓝桥杯·动态规划·洛谷
YGGP5 小时前
【Golang】LeetCode 56. 合并区间
算法·leetcode·职场和发展
_OP_CHEN5 小时前
【算法提高篇】(二)线段树之区间修改:懒标记的核心奥义与实战实现
算法·蓝桥杯·线段树·c/c++·区间查询·acm/icpc·懒标记
zheshiyangyang6 小时前
前端面试基础知识整理【Day-5】
前端·面试·职场和发展
sprintzer16 小时前
2.06-2.15力扣数学刷题
算法·leetcode·职场和发展
滴滴答滴答答18 小时前
LeetCode Hot100 之 17 有效的括号
算法·leetcode·职场和发展