关注
作者:李济民233 链接:https://www.nowcoder.com/discuss/123368?type=0&order=0&pos=6&page=0 来源:牛客网 #include<bits/stdc++.h> using namespace std; typedef long long ll; const int maxn=500010; const ll INF=(ll)(1e9)*maxn; int n,d,dis[maxn]; ll k,val[maxn]; ll dp[maxn]; deque<int> q; int zuo,you; bool in_range(int j,int i) { return zuo<=dis[i]-dis[j]&&dis[i]-dis[j]<=you; } bool test(int g) { if(g>=d) { zuo=1; you=d+g; } else { zuo=d-g; you=d+g; } for(int i=1;i<=n;i++) dp[i]=-INF; int L=0; q=deque<int>(); for(int i=1;i<=n;i++) { if(zuo<=dis[i]&&dis[i]<=you) dp[i]=val[i]; while(1) { if(L+1>=i) break; if(dis[i]-dis[L+1]<zuo) break; L++; if(dp[L]==-INF) continue; while(!q.empty()&&dp[q.back()]<=dp[L]) q.pop_back(); q.push_back(L); } while(!q.empty()&&!in_range(q.front(),i)) q.pop_front(); if(!q.empty()) dp[i]=max(dp[i],dp[q.front()]+val[i]); if(dp[i]>=k) return 1; } return 0; } int main() { scanf("%d %d %lld",&n,&d,&k); int mx=0; for(int i=1;i<=n;i++) { scanf("%d %lld",&dis[i],&val[i]); mx=max(mx,dis[i]); } int l=0,r=mx,ans=-1; while(l<=r) { int mid=(l+r)/2; if(test(mid)) { r=mid-1; ans=mid; } else l=mid+1; } printf("%d\n",ans); return 0; }
查看原帖
点赞 评论
相关推荐
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 2025年终总结 #
167763次浏览 2831人参与
# 找工作,行业重要还是岗位重要? #
84886次浏览 1679人参与
# 你面试体验感最差/最好的公司 #
13931次浏览 225人参与
# 一人说一个提前实习的好处 #
8573次浏览 177人参与
# 今年你最想重开的一场面试是? #
2940次浏览 56人参与
# 秋招落幕,你是He or Be #
8158次浏览 175人参与
# 重来一次,你会对开始求职的自己说 #
5340次浏览 135人参与
# 实习没事做是福还是祸? #
14068次浏览 217人参与
# 职场上哪些行为很加分? #
305680次浏览 3438人参与
# 大家每天通勤多久? #
68679次浏览 432人参与
# 团建是“福利”还是是 “渡劫” #
6333次浏览 141人参与
# 你小心翼翼的闯过多大的祸? #
10362次浏览 148人参与
# 比亚迪工作体验 #
73732次浏览 279人参与
# 大厂VS公务员你怎么选 #
73940次浏览 678人参与
# 工作中听到最受打击的一句话 #
4946次浏览 86人参与
# 大家实习每天都在干啥 #
106265次浏览 573人参与
# 如何排解工作中的焦虑 #
247585次浏览 2283人参与
# 长城汽车工作体验 #
12905次浏览 16人参与
# 机械人避雷的岗位/公司 #
38598次浏览 261人参与
# 秋招结束之后的日子 #
114145次浏览 1052人参与