当前位置: 首页 > news >正文

蓝桥杯真题:分巧克力(二分法)-Java版

由题目可知,该题的最终结果具有单调性,边长越大,可分蛋糕越少

可以用二分模板的向右找:  整数二分


import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;public class Main {static int n,k;  //n个块蛋糕,k个学生static int N = 100010;static int[] h = new int[N]; //分别表示宽和高static int[] w = new int[N];static BufferedReader in = new BufferedReader(new InputStreamReader(System.in));public static void main(String[] args)throws IOException {String[] init = in.readLine().split(" ");n = Integer.parseInt(init[0]);k = Integer.parseInt(init[1]);for(int i = 0;i < n; i ++) {  //存储蛋糕长宽init = in.readLine().split(" ");h[i] = Integer.parseInt(init[0]);w[i] = Integer.parseInt(init[1]);}//用二分的向右找模板,找一个 <= 正确结果的 的最大值int l = 1,r = 100000;while(l < r) {int mid = l + r + 1 >> 1;if(check(mid)) l = mid;else r = mid - 1;}System.out.println(l);in.close();
}public static boolean check(int mid) {    //mid代表切下来的边长int res = 0;for(int i = 0;i < n;i ++) {res += (h[i] / mid) * (w[i] / mid);if(res >= k) return true;   //满足条件了就可以退出,可以算剪枝}return false;}
}

http://www.lryc.cn/news/254658.html

相关文章:

  • c++面试题
  • 高精度加法,减法,乘法,除法(上)(C语言)
  • C++新经典模板与泛型编程:SFINAE特性的信息萃取
  • java单人聊天
  • nodejs环境安装
  • R语言进行正态分布检验
  • 什么是SPA(Single Page Application)?它的优点和缺点是什么?
  • 由于找不到xinput1_3.dll,无法继续执行代码的多种解决方法指南,xinput1_3.dll文件修复
  • Vue---Echarts
  • uni-app实现返回刷新上一页
  • centos服务器安装docker和Rabbitmq
  • 【Redis】Redis高级特性和应用(慢查询、Pipeline、事务、Lua)
  • 【pytorch】深度学习入门一:pytorch的安装与配置(Windows版)
  • 安装postgresql驱动及python使用pyodbc指定postgresql驱动调用postgresql
  • 【OpenCV】计算机视觉图像处理基础知识
  • Course1-Week3-分类问题
  • Dockerfile 指令的最佳实践
  • Drools 入门:折扣案例
  • 微信小程序中生命周期钩子函数
  • “无忧文件安全!上海迅软DSE文件加密软件助您轻松管控分公司数据!
  • 详解线段树
  • C语言——指针的运算
  • Apache Hive(部署+SQL+FineBI构建展示)
  • python入门级简易教程
  • 模拟一个集合 里面是设备号和每日的日期
  • antdesign前端一直加载不出来
  • 排序算法介绍(一)插入排序
  • 2023新优化应用:RIME-CNN-LSTM-Attention超前24步多变量回归预测算法
  • RNN:文本生成
  • Rust UI开发(五):iced中如何进行页面布局(pick_list的使用)?(串口调试助手)