题解 | 小红的双生英雄

小红的双生英雄

https://www.nowcoder.com/practice/bb8efeec4e39421d8fe6516169c98083

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#undef DEBUG
#ifdef DEBUG
#define debug(fmt, ...) printf(fmt, ##__VA_ARGS__)
#else
#define debug(fmt, ...)
#endif

long long DP[2][6][1000];

typedef struct hero {
    long long cost;
    long long power;
    int twin;
    long long bonus;
} hero_t;


int main() {
    int n, C, m;
    int k,j;
    long long a, b;
    scanf("%d %d %d", &n, &C, &m);
    debug("n = %d, C = %d, m = %d\n", n, C, m);
    hero_t* heros = (hero_t*)malloc(sizeof(hero_t) * (n + 1));
    int i;
    for (i = 1; i <= n; i++) {
        scanf("%lld %lld", &heros[i].cost, &heros[i].power);
        heros[i].twin = heros[i].bonus = 0;
    }
    int h1, h2;
    long long bonus;
    for (i = 0; i < m; i++) {
        scanf("%d %d %lld", &h1, &h2, &bonus);
        heros[h1].twin = h2;
        heros[h2].twin = h1;
        heros[h1].bonus = bonus;
        heros[h2].bonus = bonus;
    }
    for(i = 1; i <= n; i++)
        debug("cost[%lld] power[%lld] twin[%d] bonus[%lld]\n", \
            heros[i].cost, heros[i].power, heros[i].twin, heros[i].bonus);
    memset(DP, 0 ,sizeof(DP));

    for(i = 1; i <= n; i++) {
        int sel_n = i & 1;
        int sel_l = sel_n ^ 1;
        int twin_i = heros[i].twin;

        for(k = 0; k <= 4; k++) {
            for(j = 0; j <= C; j++) {
                DP[sel_n][k][j] = DP[sel_l][k][j];
            }
        }

        if(twin_i != 0 && twin_i < i) continue;

        for(k = 1; k <= 4; k++) {
            for(j = heros[i].cost; j <= C; j++) {
                long long previous = DP[sel_l][k-1][j - heros[i].cost] + heros[i].power;
                if(previous > DP[sel_n][k][j]) {
                    DP[sel_n][k][j] = previous;
                }
            }
        }
        
        if(twin_i == 0) continue;

        for(k = 1; k <= 4; k++) {
            for(j = heros[twin_i].cost; j <= C; j++) {
                long long previous = DP[sel_l][k-1][j - heros[twin_i].cost] + heros[twin_i].power;
                if(previous > DP[sel_n][k][j]) {
                    DP[sel_n][k][j] = previous;
                }
            }
        }

        long long total_cost = heros[i].cost + heros[twin_i].cost;
        for(k = 2; k <= 4; k++) {
            for(j = total_cost; j <= C; j++) {
                long long previous = DP[sel_l][k-2][j - total_cost] + \
                            heros[i].power + heros[twin_i].power + heros[i].bonus;
                if(previous > DP[sel_n][k][j]) {
                    DP[sel_n][k][j] = previous;
                }
            }
        }

    }

    long long ans = 0;
    int sel_n = n & 1;
    for(k = 0; k <= 4; k++) {
        if(DP[sel_n][k][C] > ans) {
            ans = DP[sel_n][k][C];
        }
    }

    printf("%lld\n",ans);
    return 0;
}

全部评论

相关推荐

今天 16:40
已编辑
门头沟学院 C++
26学院本太难了,很多公司机筛就给我刷了。机会都难拿到如果是简历存在问题也欢迎拷打————————————————————分割线——————————————————————2026.3.4更新:发完贴之后,时不时投递又收到了不少的笔试/面试邀请。主要是之前投递简历出去之后基本上都是沉默状态,年后好转了不少timeline:2026.01.21&nbsp;文远知行笔试,半年多没刷算法题&nbsp;-&gt;挂&nbsp;(后续HR说春招可以重新安排笔试)2026.2.4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;小鹏汇天&nbsp;技术一面,第二周收到结果&nbsp;-&gt;挂2026.2.12&nbsp;&nbsp;&nbsp;大众Cariad代招&nbsp;技术二面&nbsp;-&gt;Offer2026.2.28&nbsp;&nbsp;&nbsp;多益网络技术面试,由于风评太差,一直在犹豫要不要接面试&nbsp;-&gt;推迟-----------分割线-----------2026.3&nbsp;月前的某一天,临时去电网报名了二批计算机岗位的笔试2026.3.6&nbsp;从上家公司实习离职,氛围最好的一家公司,leader&nbsp;说可以帮忙转正,但是流程太长,而且我们部门据说只有一个&nbsp;hc,更想要研究生,我很有可能是会被签外包公司在这里干活,就离职了。2026.3.9&nbsp;入职新公司,大众Cariad&nbsp;以外部公司的身份进组,项目组签了三年,后续三年应该都可以在这里呆,不知道有没有希望原地跳槽。2026.3.10&nbsp;电网考试居然说我通过资格审查了,短信约我去参加资格审查,请假一天,买了&nbsp;12&nbsp;号晚上的机票回成都2026.3.15&nbsp;参加国家电网计算机类笔试2026.3.17&nbsp;电网出成绩了,感觉很低。觉得已经🈚️了2026.3.18&nbsp;收到电网面试通知,通知&nbsp;3.22-3.25&nbsp;这个时间去面试,我的岗位只招&nbsp;1&nbsp;个人。据说面试只有&nbsp;2-3&nbsp;人,不知道能不能成功----------分割线-----------2026.3.21&nbsp;电网面试结束,感觉回答的还勉勉强强,大概是2个岗位分别招1个人,一共11人面试,实际来了9人2026.3.27&nbsp;出面试成绩,满分100分,早上10:20左右发现面试成绩46,我震惊了,没截图,后面过了十分钟重新看发现面试成绩给我改成58了。但同样震惊。朋友问我是不是把面试官打了,哈哈
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务