蓝桥杯备战10.分巧克力

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

暴力枚举 过70%样例

#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;
}

二分

#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;
}

相关推荐

  1. 备战10.巧克力

    2024-05-12 14:20:07       12 阅读
  2. 巧克力

    2024-05-12 14:20:07       19 阅读
  3. P8647 [ 2017 省 AB] 巧克力

    2024-05-12 14:20:07       42 阅读
  4. [ 2017 省 AB] 巧克力

    2024-05-12 14:20:07       16 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-05-12 14:20:07       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-12 14:20:07       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-12 14:20:07       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-12 14:20:07       20 阅读

热门阅读

  1. 【C++语言】模板

    2024-05-12 14:20:07       9 阅读
  2. 爬虫工具you-get

    2024-05-12 14:20:07       10 阅读
  3. Leetcode 572:另一颗树的子树

    2024-05-12 14:20:07       7 阅读
  4. 【力扣】70.爬楼梯

    2024-05-12 14:20:07       7 阅读
  5. 程序员副业录制课程

    2024-05-12 14:20:07       8 阅读
  6. 指针(3)

    2024-05-12 14:20:07       9 阅读
  7. leetcode 2316.统计无向图中无法互相到达点对数

    2024-05-12 14:20:07       9 阅读
  8. 3.1 Gateway之路由请求和转发

    2024-05-12 14:20:07       10 阅读
  9. 理解并实现区块链智能合约

    2024-05-12 14:20:07       9 阅读
  10. 验证控件的学习

    2024-05-12 14:20:07       6 阅读