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

网站建设 厦门广州高端网站建设公司

网站建设 厦门,广州高端网站建设公司,外贸网站优化服务,网络空间购买1. 题意 给定一个数组,和一个最多次操作次数。每次操作可以将数组中的一个数 x x x分成两个数 t x − t t\quad x-t tx−t。问 m a x O p e r a t i o n C n t maxOperationCnt maxOperationCnt次操作后,数组中最大的数最小的值是多少。 2. 题解 这个…

1. 题意

给定一个数组,和一个最多次操作次数。每次操作可以将数组中的一个数 x x x分成两个数 t x − t t\quad x-t txt。问 m a x O p e r a t i o n C n t maxOperationCnt maxOperationCnt次操作后,数组中最大的数最小的值是多少。

2. 题解

这个题,我们需要转换思路,不要去想怎么分,而是经过操作后数组中有几个数。对于一个数 x x x,要使它分割后小于 y y y, 我们肯定分割后尽量都分成每个数都为 y y y, 因此最后的堆数为 ⌈ x y ⌉ \lceil \frac{x}{y}\rceil yx, 分割的次数为 ⌊ x − 1 y ⌋ \lfloor\frac{x-1}{y}\rfloor yx1

再将数组排好序数,进行二分,每次尝试数 x x x,看需要的分割数 s p l i t C n t splitCnt splitCnt是否小于等于 m a x O p e r a t i o n C n t maxOperationCnt maxOperationCnt
s p l i t C n t = ∑ x i ∈ S ⌊ x i − 1 y ⌋ S : = { x i , x i > y } splitCnt=\sum_{x_i\in S}\lfloor\frac{x_i-1}{y}\rfloor\quad \\S :=\{x_i,x_i >y\} splitCnt=xiSyxi1S:={xi,xi>y}

  • 代码一
class Solution {
public:int logcnt(int base,int v) {int ans = 0;while (base < v) {v = (v + 1)/2;ans++;}return ans;}bool check(const vector<int> &nums, int val,int bid, int maxCnt) {int sz = nums.size();int ndcnt = 0;for (int i = bid;i < sz;i++) {ndcnt += (nums[i]  - 1) / val;}return ndcnt <= maxCnt;}int FindNotLess(const vector<int> &a, int v) {int l = 0;int r = a.size();while (l < r) {int mid = (l + r) >> 1;if (a[mid] <= v)l = mid + 1;else r = mid - 1;}return l;}int minimumSize(vector<int>& nums, int maxOperations) {sort(nums.begin(), nums.end());int sz = nums.size();int l =  1;int r = *nums.rbegin();while (l < r) {int val = (l + r) >> 1;// int idx = FindNotLess(nums, val);vector<int>::iterator it = upper_bound(nums.begin(), nums.end(), val);int ndCnt = 0;// for (int i = idx;i < sz;i++) {//     ndCnt += (nums[i] - 1) / val;// }for (;it != nums.end(); it++) {ndCnt += ((*it) - 1)/val;}if (ndCnt <= maxOperations) {r = val;}else {l = val + 1;}}return l;}
};

其实不需要排序的,直接尝试遍历整个数组就好了

  • 03xf的代码
class Solution {
public:int minimumSize(vector<int>& nums, int maxOperations) {auto check = [&](int m) -> bool {long long cnt = 0;for (int x : nums) {cnt += (x - 1) / m;}return cnt <= maxOperations;};int left = 0; // 循环不变量 check(left) == falseint right = ranges::max(nums); // 循环不变量 check(right) == truewhile (left + 1 < right) {int mid = left + (right - left) / 2;(check(mid) ? right : left) = mid;}return right;}
};

参考

03xf

http://www.ds6.com.cn/news/19623.html

相关文章:

  • 产品做推广一般上什么网站seo排名如何
  • 平台推广具体是干啥seo一个月工资一般多少
  • 淮安市汽车网站建设背景企业培训机构排名前十
  • 汕头网站定制无锡优化网站排名
  • wordpress怎么更换网站logo西安百度快照优化
  • 什么是嵌入式软件工程师引擎优化是什么工作
  • 深圳市社会保险网站百度搜索风云榜电脑版
  • 广州 网站建设网络推广网页设计seo网站关键词排名优化公司
  • 傻瓜做网站软件网站优化搜索排名
  • 杭州网站建设电话爱站工具包下载
  • 建一个网站的费用做外贸网站哪家公司好
  • 凌点视频素材网seo学院
  • 互联网专线做网站怎么做数据网络推广是网络营销的基础
  • 做电影网站需要用什么空间免费推广网站大全下载安装
  • 合肥大型网站开发公司海外推广专员
  • 济南网站优化小黑哈尔滨新闻头条今日新闻
  • 怎么做百度网站会显示图片在旁边seo1搬到哪里去了
  • 滨州淘宝网站建设推广赚钱的软件
  • 可以做网站的公司有哪些今日新闻联播
  • 网站代理商app推广引流渠道
  • 分类信息网站 建议 建设优化大师tv版
  • 门户网站建设兴田德润百度搜索使用方法
  • 开发一个彩票网站多少钱抖音广告投放平台官网
  • 小企业如何建网站东莞网站制作模板
  • 服装网站设计欣赏百度竞价推广怎么样才有效果
  • 做dota2菠菜网站自己做网站需要什么条件
  • 重庆网站开发服务器二级域名分发平台
  • 深圳专门做写字楼的网站长沙疫情最新数据消息
  • 日本雅虎网站如何做推广百度推广怎么联系
  • 百度给做网站收费多少钱成人用品哪里进货好