题意:
n个人排队去办理通行证,给出办公室开始办理的时间s和停止办理的时间d,以及办理一个人的通行证需要花费的时间t,小明也想去办理通行证,在知道n个人都是什么时间(a[i])来的情况下,小明想知道自己什么时候去自己能够办理到通行证且等待的时间最少,另外小明如果和别人同时到,他会排在这个人后面
思路:
模拟.
我们模拟经过第i个人后,办公室要在什么时间才能办理,用变量记录,一开始就是s,之后只要tim=max(tim, a[i])+t这样去更新就行,我们枚举小明在a[i]-1,这个时间点到,看需要花费多少时间,所花费的时间即为tim-a[i]+1(如果是负数,没关系,题目只要求输出什么时候到达就行,所以负数和0的效果是一样的),每次去更新下就行.最后check一下是不是tim+t<=d,也就是说是不是所有人办理完后还足够办理一次.另外我们在枚举的时候要把a[i]>=d的变量跳过.
所以这里最重要的是明白我们只需要枚举a[i]-1就可以,然后明白怎么更新办公室闲置的时间,以及花费的时间怎么求.
代码:
#include <bits/stdc++.h>using namespace std;const int maxn=1e5+5;long long a[maxn];struct p{ long long tim; long long cost;}b[maxn];bool cmp(p a, p b){ return a.cost<b.cost;}int main(){ long long s, d, t; int n; cin>>s>>d>>t>>n; int i, j; for(i=0; i<n; i++) { scanf("%lld", &a[i]); } long long tim=s; int top=0; for(i=0; i<n; i++) { if(a[i]>=d)continue; b[top].cost=tim-a[i]+1; b[top++].tim=a[i]-1; tim=max(tim, a[i])+t; if(d-tim+1<t)break; } if(d-tim>=t)return 0*PRintf("%lld/n", tim); sort(b, b+top, cmp); printf("%lld/n", b[0].tim);}
新闻热点
疑难解答