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

青岛网站互联网公司手工做衣服的网站

青岛网站互联网公司,手工做衣服的网站,wordpress 浏览量插件,企业网站建设专业服务题目如下: 拿到题我们来看一下,题目的意思,就是求出N个记录中的最大最小值,言外之意就是,如果超过了这个最大值不行,如果小于这个最小值也不行,所以我们得出,这道题是一个二分答案的题目&#x…

题目如下:

在这里插入图片描述
拿到题我们来看一下,题目的意思,就是求出N个记录中的最大最小值,言外之意就是,如果超过了这个最大值不行,如果小于这个最小值也不行,所以我们得出,这道题是一个二分答案的题目,求出分界点。
首先我们输入 N 个组别,分别输入a , b 。
我们先讨论最小值,我们写一个binary_min函数,用来二分答案的最小值,记最小值为 ans
首先,左边界为 1 通过题目我们知道 我们要求的 V在分母上 所以我们最小为1,最大则为当前a(分子)的值
下来我们开始二分,在二分答案中我们应该写成while(l<r)这样我们就不用记录中间的状态了(下面注释中会说到), mid=l+r>>1取中值,下来进入主要逻辑,当a/mid(V)<=b的时候,我们可以得出我们现在的值在分界点的左边,需要将V的值变大,那么就需要将分母上的值(mid)变小,那么我们就需要向左收缩区间令r=mid(这里说明为什么应该为l<r,我们在之前的二分中,左闭右开时,循环的条件为while(l<=r),而这次需要写成l<r,我们最终要找的是临界点 所以我们最后需要 l==r 而不是l=r+1)
当写成while(l<=r)时,错误写法

// 错误示例:使用 l <= r 但不记录答案
int binary_min(int a, int b) {int l = 1, r = a;while (l <= r) {  // 问题1:循环会在 l=r+1 时结束int mid = (l + r) / 2;if (a / mid <= b) {r = mid - 1;  // 问题2:可能错过正确答案} else {l = mid + 1;}}return l;  // 错误:循环结束时 l 可能已超出有效范围
}

最主要的就是可能会直接跳过最佳的答案,导致答案不正确(采用左闭右闭的写法时,应该确保每次右边的边界都不会被跳过,由于我们的循环条件为l<r)所以我们应该记录一下右边界的值
所以应该向右收缩时记录值

		if (a / mid <= b) {ans = mid;  // 记录当前有效解r = mid - 1;  // 向左收缩(关键:r=mid-1而非r=mid)} else {l = mid + 1;}

正确写法

int binary_min(int a, int b) {int l = 1, r = a;while (l < r) {int mid = (l + r) >> 1;if (a / mid <= b) {r = mid;  // 保留当前 mid 作为候选} else {l = mid + 1;}}return l;  // 循环结束时 l 即为答案
}

了解了这一原理,下来继续写题,我们写完函数之后试着输出一下。
在这里插入图片描述
得到了这样一组数据,为什么会出现这种呢?因为有三个记录,每个记录对应着一个最小值,对于每个 (a, b),满足条件的 V 可能形成一个区间 [min_V, max_V]。当有多组输入时,我们需要找到一个公共的 V 范围,使得所有组的条件都被满足。
代码

	ans=max(ans,binary_min(a,b));ans2=min(ans2,binary_max(a,b));

我们每次都会获得一个V我们要在所有的可能最小值里面选出一个最大的,在所有可能得最大值中选择一个最小的,以此来满足公共区间例如在上面的例子中,18已经是最小的值了,所以我们答案可以大于等于18,所以我们需要取这一堆数的最大值,同理
在这里插入图片描述
获得了每组数据的最大上限,大的不一定全部满足,小的一定全部满足,找到其中的最小值,就是我们最终答案的最大值

AC代码:

#include <iostream>
#include<limits.h>
#include<algorithm>
using namespace std;
//找最大值
int binary_max(int a,int b){int l=1,r=a;while(l<r){int mid=(l+r+1)>>1;if((a/mid)>=b){l=mid;}elser=mid-1;}return l;
}//找最小值
int binary_min(int a,int b){int l=1,r=a;while(l<r){int mid=(l+r)>>1;if((a/mid)<=b){r=mid;}elsel=mid+1;}return l;
}
int main()
{ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);int N;cin>>N;int ans=INT_MIN,ans2=INT_MAX;while(N--){int a,b;cin>>a>>b;ans=max(ans,binary_min(a,b));ans2=min(ans2,binary_max(a,b));}cout<<ans<<" "<<ans2;return 0;
}

文章转载自:

http://Fo70wySC.ysrcf.cn
http://hEv65KZY.ysrcf.cn
http://gmkouFBa.ysrcf.cn
http://w70zBte4.ysrcf.cn
http://lD1i5A1b.ysrcf.cn
http://4xu8qzUw.ysrcf.cn
http://DnVNFWhw.ysrcf.cn
http://b7Cv9IGw.ysrcf.cn
http://cIrHH31h.ysrcf.cn
http://emtMBHh4.ysrcf.cn
http://HyO5BDpi.ysrcf.cn
http://WAu76E6V.ysrcf.cn
http://xbJOZwXb.ysrcf.cn
http://yZp6gNeD.ysrcf.cn
http://4gNzpgqj.ysrcf.cn
http://J3u9Lock.ysrcf.cn
http://B1lFTyBR.ysrcf.cn
http://IPFiWKEQ.ysrcf.cn
http://UKtGznvU.ysrcf.cn
http://96YMEad1.ysrcf.cn
http://8y3CAAle.ysrcf.cn
http://OpkNu5a3.ysrcf.cn
http://UqHgVWM9.ysrcf.cn
http://aMcQ14zC.ysrcf.cn
http://VQiO0Yd2.ysrcf.cn
http://5eCamHia.ysrcf.cn
http://AT7dBr7C.ysrcf.cn
http://0PNMEcwO.ysrcf.cn
http://Sp12IpEN.ysrcf.cn
http://Ozfv0FIi.ysrcf.cn
http://www.dtcms.com/wzjs/739683.html

相关文章:

  • 做购物网站的引言网站开发 博客
  • 做网站如何盈利国家胸痛中心建设网站
  • 网站统计工具是什么意思网站建设与管理ppt
  • 郑州网站推广公司信息详情页制作模板
  • 平顶山建设局网站做电脑系统那个网站好点
  • 免费制作的网站网页设计网站模板网站建设网页模板
  • 网站升级 html重庆seo优化公司
  • 网站数据库访问企业管理系统设计
  • 西安知名的集团门户网站建设费用网站建设是否属于技术合同
  • 上海平台网站建设公爱站网官网关键词查询
  • 上海公司黄页网站wordpress导入微信
  • 响应式网站好处深圳最新招聘
  • 网站效果检测c2c模式的网站有哪些
  • 百度商桥网站代码去哪里添加非你莫属做网站的卖网币起家的
  • 网站策划任职要求网站建设吉金手指专业15
  • 南京淄博网站建设方案钢管网站建设
  • 做哪个app软件网站排名优化和竞价
  • 合肥建设干部学校网站首页dw做的网站怎么全屏
  • 沈阳做网站需要多少钱响应式网站 哪些
  • 网站做专题提升权重机械 网站源码
  • 做python项目的网站深圳免费网站排名优化
  • 客户评价 网站商城网站验收
  • 网站提示404error顺企网哈尔滨网站建设
  • 内网网站建设主流语言网站后台发布图片upload failed
  • 宜宾建设机械网站南宁模板开发建站
  • 网站跳出率因素菏泽网站建设方案
  • wordpress文章大网站移动端开发语言
  • 做cps要做什么类型的网站鹰潭网站商城建设
  • 学校网站开发的背景芍药居网站建设公司
  • 黑龙江住房和城乡建设厅网站首页小清新网站源码