• 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. }

    最后提交:

  • 相关阅读:
    如何判断一个低代码平台是否专业?
    tensorflow 中的Variable 和 get_variable
    VBA技术资料MF63:遍历形状并改变颜色
    Qt CMake 国际化相关配置
    02-课程发布
    视觉语言模型能多好地看到图像细节? [单位:蒙纳士大学]
    STM32 RTC实验
    金仓数据库KingbaseES物理备份恢复命令选项(stanza-delete命令)
    vue实现词云图(echarts/Highcharts)
    【无标题】
  • 原文地址:https://blog.csdn.net/hacker_51/article/details/133417761