优先队列 - big先

优先队列

优先大的元素出,或者优先小的元素出

https://blog.csdn.net/yuewenyao/article/details/88764046

#include<iostream>
#include<vector>
#include<queue>
#include<algorithm>
using namespace std;
vector<long long> s, s1, e, e1;
void sort(int left, int right);
bool cmp(int wl, int hl, int i);
priority_queue<long long> q;
long long ee = 1e+9 + 7;


int main()
{
    int n(0), k(0);
    cin >> n >> k;
    for(int i = 0; i < n; i++) 
    {
        int tmp1(0);
        cin >> tmp1;
        s.push_back(tmp1);
        // s1.push_back(tmp1);
    }
    for(int i = 0; i < n; i++) 
    {
        int tmp2(0);
        cin >> tmp2;
        e.push_back(tmp2);
        // e1.push_back(tmp2);
    }
    int len = e.size();
    sort(0, len-1);
    // for(int i = 0; i < e.size(); i++) cout << e[i] << " ";
    // cout << endl;
    long long sum = 0;
    long long ans = 0;
    for(int i = 0; i < len; i++) // 从效率最高的工人降序选择,第一次只能选	一个,然后两个,三个,...,k个(最多),这个时候用优先队列来进行维护
    {
        sum += s[i];
        q.push(-s[i]);  // 填入负值是和上一个sum语句相关的
        while(q.size() > k)  // 保证最低效率情况下能获得最高的速度
        {
            sum += q.top();
            q.pop();
        }
        ans = max(ans, sum*e[i]);

    }
    // cout << ee << endl;
    cout << ans%ee;
    return 0;
}


void sort(int left, int right)  
{
if(left >= right) return;

int i = left;
int j = right;
int wl = s[left];
int hl = e[left];
while(i < j)
{
    // cout << i << " " << j << " " << left << endl;
    while(i < j && cmp(wl, hl, j)) j--;
    s[i] = s[j];
    e[i] = e[j];

    while(i < j && !cmp(wl, hl, i)) i++;
    s[j] = s[i];
    e[j] = e[i];
}
// cout << 1 << endl;
s[i] = wl;
e[i] = hl;
sort(left, i-1);
sort(i+1, right);
}
bool cmp(int wl, int hl, int i)
{
    // if(wl < w[i]) return true;
    // if(wl > w[i]) return false;
    if(hl > e[i]) return true;
    else return false;
}
posted @ 2021-04-14 22:11  SKEZhi7  阅读(44)  评论(0编辑  收藏  举报
Live2D