牛客网-牛牛找工作

链接:https://www.nowcoder.com/questionTerminal/46e837a4ea9144f5ad2021658cb54c4d

时间限制:2秒

空间限制:65536K

为了找到自己满意的工作,牛牛收集了每种工作的难度和报酬。牛牛选工作的标准是在难度不超过自身能力值的情况下, 牛牛选择报酬最高的工作。在牛牛选定了自己的工作后,牛牛的小伙伴们来找牛牛帮忙选工作,牛牛依然使用自己的标 准来帮助小伙伴们。牛牛的小伙伴太多了,于是他只好把这个任务交给了你。 输入描述: 每个输入包含一个测试用例。 每个测试用例的第一行包含两个正整数,分别表示工作的数量N(N<=100000)和小伙伴的数量M(M<=100000)。 接下来的N行每行包含两个正整数,分别表示该项工作的难度Di(Di<=1000000000)和报酬Pi(Pi<=1000000000)。 接下来的一行包含M个正整数,分别表示M个小伙伴的能力值Ai(Ai<=1000000000)。 保证不存在两项工作的报酬相同。 输出描述: 对于每个小伙伴,在单独的一行输出一个正整数表示他能得到的最高报酬。一个工作可以被多个人选择。

示例1

输入
3 3
1 100
10 1000
1000000000 1001
9 10 1000000000

输出
100
1000
1001
超时算法:
#include 
#include 
#include 
#include 
#include
#include

using namespace std;

struct job {
    int Di;//难度
    int Pi;//报酬
} Job[100001];

int Ai;

bool cmp(struct job a, struct job b) {
    return a.Pi > b.Pi; //报酬
}

int main() {
    int n, m;
    while (scanf("%d%d", &n, &m) != EOF) {
        for (int i = 0; i < n; i++) { //n为工作数量
            cin >> Job[i].Di;
            cin >> Job[i].Pi;
        }
        sort(Job, Job + n, cmp);

        for (int i = 0; i < m; i++) {//m为小伙伴数量   /*注意:这里超时了,因为10e5 * 10e5 超过2秒的时间。  1秒约10e8*/
            cin >> Ai;
            for (int j = 0; j < n; j++) {//n为工作数量
                if (Ai >= Job[j].Di) {
                    cout << Job[j].Pi<

正确解法:

#include 
#include 
#include 
#include 
#include
#include

using namespace std;

struct job {    //工作
    int Di;//难度
    int Pi;//报酬
} Job[100001];

struct ai {   //人
    int i;//序号
    int power;//能力
    int money=0;//报酬
} Ai[100001];

bool cmp(struct job a, struct job b) {
    return a.Di < b.Di; //难度
}

bool cmp2(struct ai a, struct ai b) {
    return a.power < b.power; //能力
}

bool cmp3(struct ai a, struct ai b) {
    return a.i < b.i; //序号
}

int main() {
    int n, m;
    while (scanf("%d%d", &n, &m) != EOF) {
        for (int i = 0; i < n; i++) {  //n为工作数量
            cin >> Job[i].Di;
            cin >> Job[i].Pi;
        }
        sort(Job, Job + n, cmp);

        for (int i = 0; i < m; i++) {  //m为小伙伴数量
            Ai[i].i=i;
            cin >> Ai[i].power;
        }
        sort(Ai, Ai + m, cmp2);

        //多思考,
        //人的能力 10  30 45 70
        //工作需要的能力  12 13 14 15 37 59
        // 30人的能力 大于 工作的能力12 13 14 15 所以选其中最大的赋值给30能力的人
        int j=0;
        int maxMoney=0;
        for(int i=0;iAi[i].power){ //工作的能力 大于 人的能力 ,退出
                   break;
               }
               maxMoney=max(maxMoney,Job[j].Pi);
               j++;
           }
           Ai[i].money=maxMoney;
        }
        sort(Ai, Ai + m, cmp3);
        for(int i=0;i



你可能感兴趣的:(ACM算法)