分巧克力 刷题笔记

/*

分巧克力 解题思路

二分

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

对于一块边长分别为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;

}

相关推荐
三伏5221 分钟前
Cortex-M3权威指南Cn第四、五章——笔记
笔记·cortex-m3
亲爱的非洲野猪5 分钟前
动态规划进阶:多维DP深度解析
算法·动态规划
AlenTech21 分钟前
197. 上升的温度 - 力扣(LeetCode)
算法·leetcode·职场和发展
轴测君29 分钟前
MobileNet V1
人工智能·pytorch·笔记
橘颂TA1 小时前
【Linux 网络】TCP 拥塞控制与异常处理:从原理到实践的深度剖析
linux·运维·网络·tcp/ip·算法·职场和发展·结构与算法
Aliex_git1 小时前
Claude Code 使用笔记(一)- 配置和基础
人工智能·笔记·学习·ai编程
云潮汐表1 小时前
烟台潮汐表查询2026-01-25
笔记
tobias.b1 小时前
408真题解析-2010-9-数据结构-折半查找的比较次数
java·数据结构·算法·计算机考研·408真题解析
源代码•宸1 小时前
Leetcode—404. 左叶子之和【简单】
经验分享·后端·算法·leetcode·职场和发展·golang·dfs
WBluuue2 小时前
数据结构与算法:dp优化——优化尝试和状态设计
c++·算法·leetcode·动态规划