#P11092. [ROI 2021 Day 2] 莫斯科数字

[ROI 2021 Day 2] 莫斯科数字

题目背景

翻译自 ROI 2021 D2T1

你可能熟悉罗马数字,并且也听说过莫斯科是第三个罗马的说法,所以我们隆重推出莫斯科数字。这是罗马数字的进阶版本,与之类似。在莫斯科数字系统中,数字由大写英文字母 AZ 表示。每个数字对应一个特定的值:

莫斯科数字规则如下:每个数字的值等于由它构成的各个数字的总和。数字可以有正负之分。如果一个数字右侧没有比它更大的数字,则该数字的值等于它本身;否则,该数字的值等于其本身取负。例如:

  • BBA」的值为 5+5+1=115 + 5 + 1 = 11
  • BBBC」的值为 5+(5)+(5)+10=5-5 + (-5) + (-5) + 10 = -5
  • ABC」的值为 1+(5)+10=4-1 + (-5) + 10 = 4
  • BAC」的值为 5+(1)+10=4-5 + (-1) + 10 = 4
  • ACA」的值为 1+10+1=10-1 + 10 + 1 = 10
  • CFF」的值为 10+500+500=990-10 + 500 + 500 = 990

题目描述

给定了一些数字,每个数字由大写英文字母组成(即莫斯科数字),但是一部分被替换成了问号。对于每个数字,需要确定在将问号替换为莫斯科数字字母后,可以得到的最大数字。

输入格式

第一行是一个整数 tt,表示数据组数,即数字的数量(1t500001 \le t \le 50000)。

接下来的 tt 行,每行一个字符串 sis_i,由大写英文字母和问号组成。所有字符串的长度之和不超过 300000300000

输出格式

对于每个输入,输出两行,都表示的是将问号替换为莫斯科数字字母后可以得到的最大数字。第一行是以十进制表示的最大数字值,第二行就是替换后的这个最大莫斯科数字。

4
BBBC
????
A?B?C?D
YYYYY?
-5
BBBC
20000000000000
ZZZZ
15000000000034
AZBZCZD
6000000000000
YYYYYY

提示

S=i=1tsiS=\sum\limits^{t}_{i=1}|s_i|

子任务 分值 SS\le 特殊性质
11 66 10001000 sis_i 中不包含 ?
22 99 3×1053\times10^5
33 4040 10001000 sis_i 中不包含超过三个 ?
44 2020
55 2525 3×1053\times10^5