CFCF2145B.Deck of Cards

普及-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

Monocarp 有一副从 11nn 编号的牌。起初,这些牌按照从小到大的顺序排列,11 在顶部,nn 在底部。

Monocarp 对这副牌进行了 kk 次操作。每次操作类型有三种:

  • 移除顶部的牌;
  • 移除底部的牌;
  • 移除顶部或底部的任意一张牌。

你的任务是判断每张牌的状态:它现在是否仍在牌堆中,已经被移除,还是可能两种情况都有可能。

输入格式

第一行为一个整数 tt1t1041 \le t \le 10^4),表示测试用例的数量。

每个测试用例的第一行包含两个整数 nnkk1kn21051 \le k \le n \le 2 \cdot 10^5)。

第二行是一个长度为 kk 的字符串 ss,由字符 0011 和/或 22 组成。字符串 ss 描述了 Monocarp 的操作。如果第 ii 个字符是 00,第 ii 次操作移除顶部牌;如果是 11,则移除底部牌;如果是 22,可以移除顶部或底部的任意一张牌。

输入还保证所有测试用例的 nn 之和不超过 21052 \cdot 10^5

输出格式

对于每个测试用例,输出一个长度为 nn 的字符串。第 ii 个字符如果该牌仍在牌堆中则为加号(+),如果已被移除则为减号(-),如果状态不确定则为问号(?)。

输入输出样例

  • 输入#1

    4
    4 2
    01
    3 2
    22
    1 1
    2
    7 5
    01201

    输出#1

    -++-
    ???
    -
    --?+?--
首页