蓝桥集训之游戏

蓝桥集训之游戏

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

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

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

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

      • 即当前结果为wR -- (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;
  }
相关推荐
wgc2k2 分钟前
Node.js游戏服务器项目移植 5-唯一 ID 生成方案
游戏·node.js
AI人工智能+电脑小能手3 分钟前
【大白话说Java面试题 第97题】【Mysql篇】第27题:说说分库与分表的设计?
java·开发语言·数据库·分布式·mysql·算法
yuan1999711 分钟前
双目视觉测距实现
算法
洒脱的六边形战士加辣12 分钟前
Java排序方法全解析
java·数据结构·算法
代码中介商23 分钟前
LRU缓存算法:双向链表+哈希表实现
算法·链表·缓存
lqqjuly27 分钟前
计算理论—图灵机、复杂性、信息论与机器学习的理论基础
算法
Hiter_John40 分钟前
Golang的循环语句
开发语言·算法·golang
德迅云安全-甲锵41 分钟前
浙江德迅云安全,游戏盾、高防 IP、安全加速 SCDN、高防服务器,头部产品推荐指南【2026增强版】
tcp/ip·安全·游戏
互联网科技看点1 小时前
FPS游戏鼠标终极对比:轻量化、低延迟与8K轮询率如何抉择?
游戏·计算机外设
独特的螺狮粉1 小时前
商品猜价格游戏 - 鸿蒙PC Electron框架完整技术实现指南
游戏·华为·electron·开源·harmonyos·鸿蒙