题解 P4058 [Code+#1]木材
2024-09-08 13:02:27
前言
这什么题啊,不就是个二分答案我从65到100都经历了一遍……(瞬间气哭)
\(\sf {Solution}\)
题目理解起来不难的,大意就懒得写了。
一眼二分答案。
此题属于在形如 \(\{0,0,0....1,1,1,\}\) 的序列中查找第一个 \(1\) 的题型。
算法流程:
- 初始化 \(l=0,r=inf\) ( \(r\) 尽可能大)。
- 如果 \(l=r\) ,停止循环。
- 计算中点 \(mid=\left\lfloor\dfrac{l+r}{2}\right\rfloor\)。
- 若等待 \(mid\) 个月满足条件, \(r=mid\) 。
- 否则 \(l=mid+1\) 。
- 回到2。
至于如何判断是否满足条件,写一个函数check一下就珂以了啦~
\(\sf {P.S.}\)
什么都要开unsigned long long
,否则会WA的很惨。
\(\sf {Code}\)
#include<cstdio>
using namespace std;
unsigned long long n,s,k,mid,a[200005],h[200005];
bool check(unsigned long long x)
{
unsigned long long ans=0;
for(unsigned long long i=1;i<=n;++i)
if(h[i]+x*a[i]>=k)//超过要求高度的树计算在总长度范围内
ans+=h[i]+x*a[i];
if(ans>=s)
return true;
return false;//如果满足订单需求就返回true
}
int main()
{
scanf("%lld%lld%lld",&n,&s,&k);
for(int i=1;i<=n;++i)
scanf("%lld",&h[i]);
for(int i=1;i<=n;++i)
scanf("%lld",&a[i]);
unsigned long long l=0,r=10000000000000000;//l和r的初始化
while(l<r)
{
mid=(l+r)/2;
if(check(mid))
r=mid;
else l=mid+1;
}//二分
printf("%lld",l);//输出结果
return 0;
}
最新文章
- WebClient 实现多文件/文本同时上传
- [转载]盒模型display:-webkit-box;的使用
- Android的Touch事件处理机制
- Maven之问题解决汇总
- linux下安装小鹤双拼-鹤形
- Tortoise SVN Clean up失败的解决方法
- RMAN - 备份异机恢复
- 【转】xcode APP 打包以及提交apple审核详细流程(新版本更新提交审核)
- C语言头文件的作用
- Python进阶(面向对象编程基础)(三)
- 读书笔记:java并发
- Maven 搭建SpringMvc+Spring+Mybatis详细记录
- Class类 获取Class对象
- MySQL (八)-- 事务、变量、触发器
- winform中执行任务,解决未响应界面
- Java中删除第一个集合中以某某开头的元素,删除第二个集合中以某某结尾的元素,并合并成一个集合
- flask sqlchemy 多对多的自引用关系定义
- CAS 单点登录4.24版本 登录调用其它系统并且返回客户端用其它的用户信息改造
- as3 typeof 对象类型与返回结果对照表 is as
- ReactNative应用<;DCL每日查看>;开发总结