分巧克力 刷题笔记

/*

分巧克力 解题思路

二分

直接检查看答案是否符合题目条件

对于一块边长分别为x 和y的巧克力\\

假设我们输入检查的数为k

其能分割成的 k*k 的巧克力的块数为

(x/k)*(y/k)

因为c++里面的除法是下取整的所以我们不用考虑奇偶数 是否能整除

将每一块巧克力能分成的k*k的巧克力块数加上计数器

一旦计数器超过了孩子数 我们就返回true;

如果check 不通过的话 可能是分的太大了

所以答案小于mid

于是我们让r=mid-1

如果check通过

则答案>=mid 所以我们让l=mid

重点 讨论边界情况

例如案例中

2 10

6 5

5 6

输出2

当 l指向2 r指向3

mid=(l+r)>>1;的话 mid 是2

此时check可以通过

但是l=2,r=3;

如果还是l=mid=2则陷入死循环

于是 我们让mid=(l+r+1)>>1

让其进行上取整

则 mid=3;

check不通过

此时 r=mid-1=l;

退出循环

输出l或者r即可

*/

代码

#include<iostream>

#include<algorithm>

#include<cstdio>

#include<cstring>

using namespace std;

const int N=1e5+10;

struct node{

int x;

int y;

}a[N];

int n,k;

bool check(int p){

int cnt=0;

bool flag=false;

// cout<<"p is "<<p<<endl;

for(int i=0;i<n;i++){

cnt=cnt+(a[i].x /p)*(a[i].y /p);

//cout <<cnt<<endl;

if(cnt>=k){

flag= true;

break;

}

}

return flag;

}

int main(){

cin>>n>>k;

int r=0;

for(int i=0;i<n;i++){

cin>>a[i].x >>a[i].y;

if(a[i].x >a[i].y ){

if(a[i].x >r){

r=a[i].x ;

}

}else{

if(a[i].y >r){

r=a[i].y ;

}

}

}

// cout<<r<<endl;

int l=0;

while(l<r){

int mid=(l+r+1)>>1;

//cout<<mid<<endl;

if(check(mid)){

l=mid;

}else{

r=mid-1;

}

//cout<<"l is"<<l<<endl<<"r is "<<r<<endl;

}

cout <<l;

return 0;

}

相关推荐
Cx330❀18 分钟前
《C++ 搜索二叉树》深入理解 C++ 搜索二叉树:特性、实现与应用
java·开发语言·数据结构·c++·算法·面试
不染尘.1 小时前
2025_11_5_刷题
开发语言·c++·vscode·算法·贪心算法·动态规划
2501_929177581 小时前
C++中的虚基类
开发语言·c++·算法
Blossom.1181 小时前
把AI“贴”进路灯柱:1KB决策树让老旧路灯自己报「灯头松动」
java·人工智能·python·深度学习·算法·决策树·机器学习
YuanDaima20482 小时前
安全协议设计入门:原理与分析
人工智能·笔记·安全·网络安全·密码学·安全协议·课程
yuxb733 小时前
Zabbix企业级分布式监控系统(上)
笔记·学习·zabbix
现在,此刻3 小时前
李沐深度学习笔记D1-什么是深度学习
人工智能·笔记·深度学习
墨染点香4 小时前
LeetCode 刷题【144. 二叉树的前序遍历】
数据结构·算法·leetcode
猿来是你_L5 小时前
UGUI笔记——3D坐标转换成UGUI坐标
笔记·3d
cynicme8 小时前
力扣3318——计算子数组的 x-sum I(偷懒版)
java·算法·leetcode