蓝桥集训之游戏

蓝桥集训之游戏

  • 核心思想:博弈论 + 区间dp

    • 设玩家1的最优解为A 玩家2的最优解为B

      • 1的目标就是使A-B最大 2的目标就是使B-A最大
    • 玩家1取L左端点右边子区间结果就是玩家2的最优解B-A

      • 即当前结果为w[L] -- (B-A)
    • 玩家1取R右端点左边子区间结果就是玩家2的最优解B-A

      • 即当前结果为w[R] -- (B-A)
cpp 复制代码
  #include <iostream>
  #include <cstring>
  #include <algorithm>
  
  using namespace std;
  const int N = 110;
  int w[N];
  int f[N][N];
  int n;
  
  int main()
  {
      cin>>n;
      for(int i=0;i<n;i++) cin>>w[i];
      for(int len = 1;len<=n;len++)  //区间dp
      {
          for(int i=0;i+len-1<n;i++)
          {
              int j = i+len-1;  //i左端点 j右端点
              //右子区间结果为f[i+1][j] , 左子区间结果为f[i][j-1];
              f[i][j] = max(w[i] - f[i+1][j] , w[j] - f[i][j-1]);
          }
      }
      int sum = 0,d = f[0][n-1];  //A+B-sum , A-B=f[0][n-1] 联立求解AB
      for(int i=0;i<n;i++) sum+=w[i];
      cout<<(sum+d)/2<<" "<<(sum-d)/2<<endl;
      return 0;
  }
相关推荐
Star在努力32 分钟前
C语言复习八(2025.11.18)
c语言·算法·排序算法
南山安39 分钟前
从反转字符串看透面试官的“内心戏”:你的算法思维到底怎么样?
javascript·算法·面试
雪不下1 小时前
计算机中的数学:概率(2)
算法
zs宝来了1 小时前
HOT100-二分查找类型题
算法
_w_z_j_1 小时前
数组中的最长连续子序列
数据结构·算法
地平线开发者1 小时前
征程 6E/M 计算平台部署指南
算法·自动驾驶
2501_940094021 小时前
山寨掌机 开源掌机游戏整合包 Emuelec整合包128G 一键导入整合游戏包
游戏·安卓·开源软件·软件
mit6.8241 小时前
数位dp|组合数学|差分emplace
算法
2301_764441331 小时前
新能源汽车电磁辐射高级预测
python·算法·数学建模·汽车
Keep_Trying_Go1 小时前
论文Leveraging Unlabeled Data for Crowd Counting by Learning to Rank算法详解
人工智能·pytorch·深度学习·算法·人群计数