• C2. Powering the Hero (hard version)


    题目:样例:

    输入
    1. 5
    2. 5
    3. 3 3 3 0 0
    4. 6
    5. 0 3 3 0 0 3
    6. 7
    7. 1 2 3 0 4 5 0
    8. 7
    9. 1 2 5 0 4 3 0
    10. 5
    11. 3 1 0 0 4

    输出
    6
    6
    8
    9
    4

    思路:

            贪心思维题,这道题要求的是一张一张的凑卡牌,凑到的是力量赋值卡就存储好,抽到 0 就是英雄卡,当我们存储中有力量赋值卡,就将该力量赋值给该英雄,并获得该英雄的战力,求最佳操作获得的最大战力总和是多少。

            我们将每次抽到的力量赋值卡存储的时候,遇到英雄卡,就赋值给最大存储即可,而赋值卡值最小的放到后面,倘若遇到了英雄卡,也会将该最小力量赋值卡赋值给英雄的,倘若没遇到,相当于弃用掉。

            所以我们用个优先队列存储并赋值即可。

    代码详解如下:

    1. #include
    2. #include
    3. #include
    4. #include
    5. #include
    6. #define endl '\n'
    7. #define int long long
    8. #define YES puts("YES")
    9. #define NO puts("NO")
    10. #define umap unordered_map
    11. #define All(x) (x).begin(),(x).end()
    12. #pragma GCC optimize(3,"Ofast","inline")
    13. #define ___G std::ios::sync_with_stdio(false),cin.tie(0), cout.tie(0)
    14. using namespace std;
    15. const int N = 2e6 + 10;
    16. inline void solve()
    17. {
    18. int n,ans = 0;
    19. cin >> n;
    20. // 存储力量赋值卡,优先赋值的最大战力卡
    21. priority_queue<int>q;
    22. // 开始抽卡
    23. while(n--)
    24. {
    25. int x;
    26. cin >> x;
    27. // 如果是力量赋值卡,存储好赋值卡
    28. // 如果是英雄,判断是否有赋值卡,有则获得该最佳战力
    29. if(x) q.push(x);
    30. else if(q.size()) ans += q.top(),q.pop();
    31. }
    32. // 输出最佳战力总和
    33. cout << ans << endl;
    34. }
    35. signed main()
    36. {
    37. // freopen("a.txt", "r", stdin);
    38. ___G;
    39. int _t = 1;
    40. cin >> _t;
    41. while (_t--)
    42. {
    43. solve();
    44. }
    45. return 0;
    46. }

    最后提交:

  • 相关阅读:
    Spring注解
    RocketMQ的Schedule example
    CleanMyMac X2024告别硬盘空间不足,让您的Mac电脑极速如新
    【JAVA基础】JDK8 HashMap 源码深度解析
    【电路笔记】-基尔霍夫电路定律
    MFC中如何重绘CListCtrl的表头
    vue+element纯手工完美模拟实现小米有品网站
    小程序首页搭建
    C++ STL容器底层实现原理
    清洁、对话、带娃,扫地机摆脱“人工智障”标签
  • 原文地址:https://blog.csdn.net/hacker_51/article/details/133417761