#P9087. 「SvR-2」音符

「SvR-2」音符

题目描述

本题中「子串」指:

若字符串 ss 中有一段连续的字符构成字符串 pp,则 ppss 的子串。

我们用一个字符串代替一份乐谱,用字符代替每一个音符。

我们定义「重音」表示乐谱中出现了两个连续的相同字符,如 eeeee\tt eeeee 中存在 44 个「重音」。

现在 Sept 准备写一份长度为 nn 的乐谱给 Tpes 看,他对乐谱的评价标准如下:

  • 乐谱中每出现一个「重音」,他的愤怒值就会增加 aa
  • 乐谱中每有一段长度为 kk子串中不存在「重音」,他的愤怒值就会增加 bb

现在已知 n,k,a,bn,k,a,b,请你帮 Sept 构造出一份乐谱,使得 Tpes 的愤怒值 xx 最小

输入格式

本题有多组数据。

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

接下来 TT 行,每行两个整数 n,k,a,bn,k,a,b,意义如题目所述。

输出格式

2T2 \cdot T 行,对于每组数据都输出两行:

  • 第 1 行表示 Tpes 最小的愤怒值 xx
  • 第 2 行表示你构造出的乐谱。
2
4 5 2 2
8 6 3 2
0
Sept
3
2023yyds

提示

数据规模与约定

本题采用捆绑测试。

Subtask\bf{Subtask} n\bm{n\le} n\bm{\sum n\le} T\bm{T\le} Score\bf{Score}
1\sf 1 66 1010 33 10\tt 10
2\sf 2 10310^3 2×1032\times 10^3 无特殊限制 30\tt 30
3\sf 3 无特殊限制 60\tt 60

对于 100%100\% 的数据,有 2T1002\le T\le 1002n,k1052\le n,k\le 10^51a,b1091\le a,b\le 10^9。单组数据内保证 n2×105\sum n\le 2\times 10^5

输出注意事项

输出 xx 和构造乐谱可以看作是两个子问题,如果你只会完成其中的一个,请在另一个子问题对应的地方用符合要求的字符或数字占位。

乐谱中你可以输出任意字符,包括数字、大小写字母等,但不能出现空格

Special Judge 返回信息说明

本题采用 Special Judge 判断你的答案是否正确。

checker.cpp 将会以 Score=A,Type=B\texttt{Score=}\text A,\texttt{Type=}\text B 的方式返回信息。

Score\tt Score 类表示你的得分情况,A\text A 有以下取值:

  • A=1\text A=1,表示含义如下:
    $\underline\text{Accepted.} \texttt{ Your Ans and SM are both proper.}$
    代表 TT 组答案全部符合要求。
  • A=2\text A=2,表示含义如下:
    $\underline\text{Partially Correct.}\texttt{ All Ans are right.}$
    表示该测试点中你的回答中 xx 全部正确,你能得到该测试点 20%20\% 的分数。
  • A=3\text A=3,表示含义如下:
    $\underline\text{Partially Correct.}\texttt{ You pass 70\% tests!}$
    表示该测试点中你的回答正确的组数不少于0.7×T\lfloor0.7\times T\rfloorxx 与乐谱均符合要求),你能得到该测试点 10%10\% 的分数。
  • A=4\text A=4,表示该测试点你只能拿到 00 分。

Type\tt Type 类表示你的得分情况,B\text B 有以下取值:

  • B=0\text B=0,表示你的答案全部正确,与 A=1\text A=1 配对。
  • B=1\text B=1,表示含义如下:
    $\underline\text{Wrong Answer.}\texttt{ The length of your SM is not right!}$
    代表你在一组数据中构造的乐谱的长度不为 nn
  • B=2\text B=2,表示含义如下:
    $\underline\text{Wrong Answer.}\texttt{ Your Ans is not right!}$
    代表你在一组数据中 xx 的值错误。
  • B=3\text B=3,表示含义如下:
    $\underline\text{Wrong Answer.}\texttt{ Your Ans and SM are not matched!}$
    代表你在一组数据中构造的乐谱使 Tpes 产生的愤怒值不为 xx

这里 Ans, SM\text{Ans, SM} 分别表示 Answer(xx 的值)和 Sheet Music(乐谱)。

注意到 Type\tt Type 只会反映你在该测试点中第一次错误的类型。