• C. Card Game


    题目:样例:

    输入
    1. 4
    2. 4
    3. -4 1 -3 5
    4. 4
    5. 1 -2 3 -4
    6. 3
    7. -1 3 -5
    8. 1
    9. -1

    输出
    5
    4
    2
    0

    思路:

            这里的题意就是,

            当我们 i 取奇数的时候,可以获得该奇数 i 的值,并去掉当前卡牌。

            当我们 i 取偶数的时候,去掉当前卡牌。

            这里我们去掉当前卡牌后,后面的卡牌下标 i 就会变化,后面的 i 的奇偶性就会变化。

            所以当我们一个一个从后面开始取数的时候,就可以巧妙的避开这些变化,之后就是贪心操作。

    代码详解如下:

    1. #include
    2. #include
    3. #include
    4. #include
    5. #define endl '\n'
    6. #define int long long
    7. #define YES puts("YES")
    8. #define NO puts("NO")
    9. #define umap unordered_map
    10. #define uset unordered_set
    11. #pragma GCC optimize(3,"Ofast","inline")
    12. #define ___G std::ios::sync_with_stdio(false),cin.tie(0), cout.tie(0)
    13. using namespace std;
    14. const int N = 2e6 + 10;
    15. inline void solve()
    16. {
    17. int n;
    18. cin >> n;
    19. umap<int,int>a; // 存储卡牌数值
    20. for(int i = 1;i <= n;++i)
    21. {
    22. cin >> a[i];
    23. }
    24. // now 是取得的值多少
    25. int now = 0,ans = 0;
    26. // 开始贪心取值
    27. // 从后面开始取值,是因为当我们取一个 i 值后
    28. // 后面的 下标 i 就会变化,我们从后面 i 开始取值
    29. // 巧妙的避开这些变化
    30. for(int i = n;i > 0;--i)
    31. {
    32. // 当我们取得的 i 是偶数的时候
    33. if(i % 2 == 0)
    34. {
    35. // 更新我们的ans
    36. ans = max(ans,now);
    37. }else
    38. {
    39. // 当我们取的 i 是奇数的时候,说明当前的 a[i] 也是可取的
    40. // 继续更新 ans
    41. ans = max(ans,a[i] + now);
    42. }
    43. // now 取值,我们只取 >= 0 更好的数值
    44. now += max(a[i],(int)0);
    45. }
    46. // 输出答案
    47. cout << ans << endl;
    48. }
    49. signed main()
    50. {
    51. // freopen("a.txt", "r", stdin);
    52. ___G;
    53. int _t = 1;
    54. cin >> _t;
    55. while (_t--)
    56. {
    57. solve();
    58. }
    59. return 0;
    60. }

    最后提交:

  • 相关阅读:
    1785. 构成特定和需要添加的最少元素
    IDEA的常用设置
    Ubuntu系统之管理文件权限二
    求臻医学:实体肿瘤FDA/NMPA新获批抗癌药物/适应症盘点
    2. 工业大数据的特点
    (pytorch进阶之路三)conv2d
    PowerDsigner 数据库逆向pdm数模 常见数据库连接问题
    图像直方图的基础知识
    Vue+Vite+TS
    Linux:无法接收组播数据
  • 原文地址:https://blog.csdn.net/hacker_51/article/details/133363635