蓝桥杯备战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;
}
相关推荐
dayuOK63073 天前
写作卡壳怎么办?我的“5分钟启动法”
人工智能·职场和发展·自动化·新媒体运营·媒体
枫子有风3 天前
LLM-Agent智能体(大厂面试常问)
面试·职场和发展·llm·agent
重生之后端学习3 天前
Java入门
java·开发语言·职场和发展
AIHR数智引擎3 天前
KPI物理失效:AI原生组织的效能重构与技能度量
人工智能·经验分享·职场和发展·重构·ai-native·aihr
想吃火锅10053 天前
【leetcode】121.买卖股票的最佳时机js/c++
算法·leetcode·职场和发展
程序员小远3 天前
自动化测试基础知识总结
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
嘿黑嘿呦3 天前
chap 8排序
算法·蓝桥杯·排序算法·软件工程
小欣加油3 天前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展
旧曲重听13 天前
2026前端技术从「夯」到「拉」
前端·程序人生·职场和发展·软件工程
javaDocker3 天前
某大厂AI应用开发面试题
面试·职场和发展