TouchStone
  Please Login
Login Sign Up
 Homepage  Problem Set  Examinations  Submissions  Discussions  Statistics
  • Home
  • Problem Set
  • P3218
  • Problem
  • P3218多项式开方(小朋友和二叉树)
    Limits : Time Limit : 100000 MS   Memory Limit : 265536 KB
    Judgment Tips : 4s
    Description

    我们的小朋友很喜欢计算机科学,而且尤其喜欢二叉树。
    考虑一个含有n个互异正整数的序列c[1],c[2],...,c[n]。如果一棵带点权的有根二叉树满足其所有顶点的权值都在集合{c[1],c[2],...,c[n]}中,我们的小朋友就会将其称作神犇的。并且他认为,一棵带点权的树的权值,是其所有顶点权值的总和。
    给出一个整数m,你能对于任意的s(1<=s<=m)计算出权值为s的神犇二叉树的个数吗?请参照样例以更好的理解什么样的两棵二叉树会被视为不同的。
    我们只需要知道答案关于998244353(=7*17*223+1,一个质数)取模后的值。

    Input Format

    第一行有2个整数 n,m(1<=n<=105; 1<=m<=105)。
    第二行有n个用空格隔开的互异的整数 c[1],c[2],...,c[n](1<=c[i]<=105)。

    Output Format

    输出m行,每行有一个整数。第i行应当含有权值恰为i的神犇二叉树的总数。请输出答案关于998244353取模后的结果。

    Sample Input

    样例输入1:
    2 3
    1 2 

    样例输入2:
    3 10
    9 4 3 

    样例输入3:
    5 10
    13 10 6 4 15 

    Sample Output

    样例输出1:
    1
    3
    9

    样例输出2:
    0
    0
    1
    1
    0
    2
    4
    2
    6
    15

    样例输出3:
    0
    0
    0
    1
    0
    1
    0
    2
    0
    5

    Hint

    样例解释:
    第一组样例中,s=3的二叉树是这9个: