#L2078. 「JSOI2016」无界单词

    ID: 4839 传统题 1000ms 256MiB 尝试: 1 已通过: 1 难度: 10 上传者: 标签>动态规划字符串KMP组合数学莫比乌斯反演

「JSOI2016」无界单词

题目描述

对于一个单词 SS,如果存在一个长度 ll,满足 0<l<S0 < l < |S|,并且使得 SS 长度为 ll 的前缀与 SS 长度为 ll 的后缀相同,则称 SS 是有界的。例如 aabaaababab 都是有界的字符串。如果一个单词不存在这样的 ll,则称之为无界单词。

现在考虑所有仅由字母 ab 组成的长度为 NN 的字符串,我们需要回答:

  1. 一共有多少个无界单词?
  2. 这些无界单词中,按字典序排列第 KK 小的单词是哪一个?

输入格式

  • 本题有多组数据。
  • 第一行包含一个正整数 TT,表示测试数据的组数;
  • 接下来 TT 行,每行包含两个正整数 NNKK,表示一组测试数据。

输出格式

对于每一个测试数据,输出两行:

  • 第一行包含一个整数,表示长度为 NN 的无界单词的数量;
  • 第二行包含一个长度为 NN 的字符串,表示第 KK 小的无界单词。

样例

输入

5
5 1
5 2
5 3
5 4
5 5

输出

12
aaaab
12
aaabb
12
aabab
12
aabbb
12
ababb

数据范围与提示

  • 对于 20%20\% 的数据,满足 N20N \le 20
  • 对于全部数据,满足 1T51 \le T \le 51N641 \le N \le 64,并且保证对于任意测试数据,总存在第 KK 小的无界单词。