POJ2431
作者:互联网
解答一下为什么要用全长减去加油站的距离呢,因为,如果在某个加油站只加一次油就能到终点的话,势必就会加最少次数的油。
#include <iostream>
#include<cstdlib>
#include<cstdio>
#include<stack>
#include<algorithm>
#include<cstring>
#include<queue>
#include<cmath>
#include<vector>
#include<map>
#include<set>
using namespace std;
int l[10010];
int p[10010];
struct y{
int l;
int p;
}a[10010];
bool cmp(y a1,y a2) {
return a1.l < a2.l;
}
int n;
int L;
int P;
int main()
{
memset(l, 0, sizeof(l));
memset(p, 0, sizeof(p));
scanf("%d",&n);
for(int i=0;i<n;i++){
scanf("%d %d",&a[i].l,&a[i].p);
}
scanf("%d %d",&L,&P);
for(int i=0;i<=n;i++){
a[i].l=L-a[i].l;
}
int ans=0;
int pos=0;
int t=P;
int dis=0;
a[n].l=L;
a[n].p=0;
sort(a,a+n+1,cmp);
priority_queue<int>q;
for(int i=0;i<=n;i++){
dis=a[i].l-pos;
while(t-dis<0){
if(q.empty()){
printf("-1\n");
return 0;
}
t+=q.top();
ans++;
q.pop();
}
pos=a[i].l;
t=t-dis;
q.push(a[i].p);
}
printf("%d\n",ans);
return 0;
}
标签:include,int,memset,a1,POJ2431,sizeof,10010 来源: https://www.cnblogs.com/A1han/p/15963543.html