1. Job Roadmap
  2. Home
  3. Problem Set
  4. codenotelist
  5. Forum
  6. course
  7. Shore Share Sessions
  8. Record
  1. Login
  2. Sign Up
  3. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
    ZhContent TextSol AI分析

解题思路

这个博弈中,玩家从当前数组中任选一个元素 aja_jaj​(其在当前数组中的位置为 ppp),并得到分数 aj−pa_j-paj​−p,随后删除该元素。两人轮流、都采取最优策略,判断先手 Koa 的最终结果。

关键观察:当前位置 ppp 等于“当前仍然存在且下标小于 jjj 的元素个数 + 1”。如果把原数组下标从 000 开始,设还未被删除的元素集合用一个比特掩码 mask 表示,则当选择下标 jjj 时:

p=1+popcount(mask & ((1≪j)−1))p = 1 + \text{popcount}\big(mask \ \&\ ((1\ll j)-1)\big) p=1+popcount(mask & ((1≪j)−1))

P4284.第3题-数组移动游戏

    3000ms Tried: 12 Accepted: 4 Difficulty: 7 所属公司 : 蚂蚁
    算法与标签>动态规划

题目内容

Koa 和她的朋友进行如下游戏。

初始有长度为 nnn 的非负整数数组 a=a=a={a1,a2,…,ana_1,a_2,…,a_na1​,a2​,…,an​}。

他们轮流进行操作,Koa 先手。在每次操作中,玩家选择原数组下标为 jjj 的元素(其值为 aja_jaj​ )。记它在当前数组中的位置为 ppp (从 111 开始计数),则本次操作得分为 aj−pa_j-paj​−p 。删除该元素后,原数组中位于其后的元素向前移动一个位置。

当数组为空时,游戏结束,得分更高的玩家获胜,若两人得分相同则为平局。双方均采取最优策略,请判断最终结果。

输入描述

第一行输入整数 t(1≤t≤10)t(1≤t≤10)t(1≤t≤10) ,表示测试用例数量。

对于每个测试用例:

  • 第一行输入整数 n(1≤n≤20)n(1≤n≤20)n(1≤n≤20) ,表示数组长度。

  • 第二行输入 nnn 个非负整数 a1,a2,…,an(0≤ai≤109)a_1,a_2,…,a_n(0≤a_i≤10^9)a1​,a2​,…,an​(0≤ai​≤109) 。

输出描述

对于每个测试用例,输出一个字符串:

若 Koa 最终得分大于对手,输出 WINWINWIN ;

若 Koa 最终得分小于对手,输出 LOSELOSELOSE ;

若两人得分相同,输出 DRAWDRAWDRAW 。

样例1

输入

2
3
5 1 1
4
1 2 3 4

输出

WIN
DRAW

登录后即可使用 AI 分析。

模式
倒计时时长
:

最长 10 小时 59 分;应用后按此时长重新开始。

提示:点击提交记录在左侧题面区域查看详情
题库
AI分析设置
留空使用官方API Key,每天有次数限制(自定义API Key仅限会员和管理员使用,不限次数)
会员和管理员可切换模型;切到 Kimi/智谱/通义/豆包时需填写对应供应商 API Key
升级会员,可将运行与提交冷却时间缩短至 1 秒起

Status

  • Judging Queue
  • Service Status

Development

  • Open Source

Support

  • Help
  • Contact Us

About

  • About
  • Privacy
  • Terms of Service
  • Copyright Complaint
  1. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
  2. Legacy mode
  3. Theme
    1. Light
    2. Dark
  1. 京ICP备2025123107号-1
  2. Worker 0, 71ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

请使用微信扫描下方二维码完成注册

Forgot password or username?