#1515. LibreOJ

LibreOJ

题目描述

Source: Codeforces Goodbye 2017 G. New Year and Original Order

LibreOJ 又锅了。

在锅了的 LibreOJ 中,一道题目的总得分通过如下方式计算:

  1. 取出此题的所有提交记录,得到序列 A

  2. 对于 A 的每个元素,假设其得分为 xx,对总得分的贡献为 xf(x)xf(x)

其中 f(x)=atoi(sort(itoa(x, b)), b)f(x)=\texttt{atoi(sort(itoa(x, b)), b)}

itoa(x, b) 表示将正整数 xxbb 进制形式转换得到的字符串。

sort(s) 表示将字符串 ss 中的字符按照升序排序得到的字符串。

atoi(s, b) 表示将字符串 ssbb 进制形式转换得到的正整数。

例如:
 itoa(184, 3) = "20211"
 sort("20211") = "01122"
 atoi("01122", 3) = 44
则当 b=3b=3f(184)=44f(184)=44

LibreOJ 的第 -1 题有着 nn 个提交记录,第 ii 个提交记录的得分为 ii,请你求出第 -1 题的总得分。

形式化地说,你需要求出 i=1nif(i)\displaystyle\sum_{i=1}^{n}if(i)

为了方便输出,你只需要求出答案对 998,244,353998,244,353 取模的结果即可。

输入格式

本题输入文件包含多组数据。

第一行一个正整数 TT,表示数据组数。

第二行一个正整数 bb,意义见题目描述。

接下来每行表示一组数据。

每组数据一行一个bb 进制形式表示的正整数 nn,意义见题目描述。

输出格式

对于每组数据,输出一行一个整数表示答案。

样例 1

3
10
5
10
100
55
295
221530

对于前两组数据,除了 f(10)=1f(10)=1 之外,其它运算需要的 f(x)=xf(x)=x

所以 n=5n=5 时答案为 12+22+32+42+52=551^2+2^2+3^2+4^2+5^2=55

n=10n=10 时答案为 12+22++92+10=2951^2+2^2+\cdots+9^2+10=295

2
2
111
1001010010100101010001100101101111010110001110
98
588970119

数据范围与提示

定义 Len=T+logb(n)\mathrm{Len}=T+\sum\lfloor\log_b(n)\rfloor

对于所有测试点:T20T\le 202b102\le b\le 10n101000n\le 10^{1000}Len1000\mathrm{Len}\le 1000

每个测试点的具体限制见下表:

测试点编号 nn\le Len\mathrm{Len}\le T=T= b=2b=2
121\sim2 10510^5 55 11 不保证
343\sim4 340340 2020
585\sim8 10100010^{1000} 10001000 11
9109\sim10 保证
111411\sim14 1010
152015\sim20 不保证

Author: PinkRabbit