zoj1731(优先队列)

2017-07-15  本文已影响0人  Alan66

原文转载至:http://blog.csdn.net/fenrir1205/article/details/8275011

#include <iostream>  
#include <cstdio>  
#include <queue>  
#include <cstring>  
using namespace std;  
  
struct Schedule  
{  
    int profit;  
    int dt;  
    //先处理高利润的  
    bool operator<(const Schedule &rhs)const {  
        return profit<rhs.profit;  
  
    }  
};  
  
bool used[10001];  
priority_queue<Schedule> que;  
  
int main()  
{  
    int n;  
    while(scanf("%d",&n)!=EOF){  
        while(!que.empty())que.pop();  
        int max = 0;  
        for (int i=0;i<n;i++){  
            Schedule prod;  
            scanf("%d %d",&prod.profit,&prod.dt);  
            if (prod.dt>max) max = prod.dt;  
            que.push(prod);  
        }  
        memset(used,false,sizeof(bool)*(max+1));  
        long long sum =0;  
        int current = 0;  
        //从前面往后面去检查,对于每一个products,从其deadtime开始往前寻找没有被标记过的时间点直至时间0点或者找到没有被标记的,然后标记,并把这个profit加起来。  
        while(!que.empty()){  
            Schedule prod = que.top();  
            que.pop();  
            while(prod.dt--){  
                if (!used[prod.dt]){  
                    used[prod.dt] = true;  
                    sum+=prod.profit;  
                    break;  
                }  
            }  
        }  
        printf("%d\n",sum);  
    }  
    return 0;  
}  
上一篇 下一篇

猜你喜欢

热点阅读