思路:
首先发现单调性,灵活性增加 \(x+1\) 的答案肯定不会比增加 \(x\) 的答案更劣。
那么可以二分求 \(g\),则机器人每次可以移动 \([\max(d-mid,1),d+mid]\) 这个区间内的距离,为了方便,设为 \([l,r]\)。
考虑动态规划求得能走到的最大分数,令 \(dp_i\) 表示走到第 \(i\) 个格子的最大分数,则状态转移方程为:
\[dp_i = s_i + \max\limits_{j=0}^{i-1} [x_i – r \le x_j] [x_j \le x_i – l] dp_j \]
可以使用单调队列维护:
-
若当前队尾为 \(j\),且 \(x_j < x_i – r\),则这个 \(j\) 无法对 \(dp_i\) 造成贡献,直接不断弹出即可。
-
若当前队头为 \(j\),且 \(x_{j+1} \le x_i – l\),则这个 \(j+1\) 可以对 \(dp_i\) 造成贡献,不断插入即可。
-
因为要维护最大值,可以使用单调队列。
时间复杂度为 \(O(N \log W)\)。
完整代码:
#include<bits/stdc++.h>
#define Add(x,y) (x+y>=mod)?(x+y-mod):(x+y)
#define lowbit(x) x&(-x)
#define pi pair<ll,ll>
#define pii pair<ll,pair<ll,ll>>
#define iip pair<pair<ll,ll>,ll>
#define ppii pair<pair<ll,ll>,pair<ll,ll>>
#define fi first
#define se second
#define full(l,r,x) for(auto it=l;it!=r;it++) (*it)=x
#define Full(a) memset(a,0,sizeof(a))
#define open(s1,s2) freopen(s1,"r",stdin),freopen(s2,"w",stdout);
using namespace std;
typedef double db;
typedef unsigned long long ull;
typedef long long ll;
bool Begin;
const ll N=5e5+10;
inline ll read(){
ll x=0,f=1;
char c=getchar();
while(c<'0'||c>'9'){
if(c=='-')
f=-1;
c=getchar();
}
while(c>='0'&&c<='9'){
x=(x<<1)+(x<<3)+(c^48);
c=getchar();
}
return x*f;
}
inline void write(ll x){
if(x<0){
putchar('-');
x=-x;
}
if(x>9)
write(x/10);
putchar(x%10+'0');
}
ll n,d,k,l,r,head,tail,ans=-1;
ll a[N],b[N],dp[N],Q[N];
ll check(ll l,ll r){
head=1,tail=0;
ll sum=0,x=1,y=0;
for(int i=1;i<=n+1;i++){
if(i>1)
dp[i]=-1e18;
while(a[y+1]<=a[i]-l&&y<=n){
y++;
while(dp[y]>dp[Q[tail]]&&tail>=head)
tail--;
if(dp[y]>=-1e18)
Q[++tail]=y;
}
while(a[x]<a[i]-r&&x<=n){
if(Q[head]==x)
head++;
x++;
}
if(tail>=head)
dp[i]=b[i]+dp[Q[head]];
sum=max(sum,dp[i]);
}
return sum;
}
bool End;
int main(){
// open("A.in","A.out");
n=read(),d=read(),k=read();
for(int i=1;i<=n;i++){
a[i+1]=read();
b[i+1]=read();
}
l=0,r=1e9;
while(l<=r){
ll mid=(l+r)>>1;
if(check(max(d-mid,1ll),d+mid)>=k){
r=mid-1;
ans=mid;
}
else
l=mid+1;
}
write(ans);
cerr<<'\n'<<abs(&Begin-&End)/1048576<<"MB";
return 0;
}
1.本站内容仅供参考,不作为任何法律依据。用户在使用本站内容时,应自行判断其真实性、准确性和完整性,并承担相应风险。
2.本站部分内容来源于互联网,仅用于交流学习研究知识,若侵犯了您的合法权益,请及时邮件或站内私信与本站联系,我们将尽快予以处理。
3.本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
4.根据《计算机软件保护条例》第十七条规定“为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。”您需知晓本站所有内容资源均来源于网络,仅供用户交流学习与研究使用,版权归属原版权方所有,版权争议与本站无关,用户本人下载后不能用作商业或非法用途,需在24个小时之内从您的电脑中彻底删除上述内容,否则后果均由用户承担责任;如果您访问和下载此文件,表示您同意只将此文件用于参考、学习而非其他用途,否则一切后果请您自行承担,如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
5.本站是非经营性个人站点,所有软件信息均来自网络,所有资源仅供学习参考研究目的,并不贩卖软件,不存在任何商业目的及用途
暂无评论内容