CFCF2178I.Numbers or Fireworks

NOI/NOI+/CTSC

官方

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

现在所有礼物都已经送达,北极终于恢复了平静——是时候用一场壮观的新年烟花秀来庆祝了!

北极被建模为一个平面直角坐标系,有 nn 个城市分别位于不同的整点上。你还得到了一个整数 kk

对于城市集合的任意一个真子集 ^{\text{∗}} TTTT 可以为空),我们这样定义其爆炸性:

  1. 每个在 TT 中的城市发射一枚烟花。
  2. 对于每个不属于 TT 的城市 cc,记 ff 为距离 cc 恰好为 k\sqrt{k} 的烟花发射城市的数量。给该城市 cc 赋值 (f+1)(f+1)
  3. TT 的爆炸性为步骤 2 中所有被赋值城市数值的乘积。

请你计算所有 2n12^n-1 个非全集真子集 TT 的爆炸性之和。由于答案可能非常大,请输出答案对 998244353998\,244\,353 取模后的结果。

^{\text{∗}} 真子集定义为严格小于全集的子集(即不是全集本身)。

^{\text{†}} 两点 (x,y)(x, y)(p,q)(p, q) 之间的欧几里得距离定义为 (xp)2+(yq)2\sqrt{(x-p)^2 + (y-q)^2}

输入格式

每组测试数据包含多组测试用例。第一行包含测试用例组数 tt1t10001 \le t \le 1000)。接下来 tt 组数据,每组描述如下:

每组数据的第一行包含两个整数 nnkk2n312 \le n \le 311k21041 \leq k \leq 2 \cdot 10^4)。

接下来 nn 行,每行两个整数 xix_iyiy_i1xi,yi1001 \leq x_i, y_i \leq 100),表示第 ii 个城市的横纵坐标。保证城市间的坐标各不相同。

保证所有测试用例的 n3n^3 之和不超过 31331^3

输出格式

对于每个测试用例,输出一个整数,表示所有真子集 TT 的爆炸性之和,对 998244353998\,244\,353 取模后的结果。

输入输出样例

  • 输入#1

    4
    3 1
    1 2
    2 1
    2 2
    2 20000
    1 1
    100 100
    9 5
    1 1
    1 2
    1 3
    2 1
    2 2
    2 3
    3 1
    3 2
    3 3
    13 25
    50 50
    55 50
    54 53
    53 54
    50 55
    47 54
    46 53
    45 50
    46 47
    47 46
    50 45
    53 46
    54 47

    输出#1

    16
    3
    8255
    560112

说明/提示

在第一个测试用例中,所有 231=72^3 - 1 = 7 种烟花发射方案如下。未被选中发射烟花的城市,其被分配的数值圈出表示。

总爆炸性为 (111)+(12)+(21)+(22)+(3)+(2)+(2)=16(1 \cdot 1 \cdot 1)+(1 \cdot 2)+(2 \cdot 1)+(2 \cdot 2)+(3)+(2)+(2)=16

在第二个测试用例里,共有 221=32^2-1=3 种烟花发射方式。任意一种方案,从 (1,1)(1,1)(100,100)(100,100) 的欧几里得距离为 (1001)2+(1001)2=1960220000\sqrt{(100-1)^2+(100-1)^2}=\sqrt{19\,602}\neq\sqrt{20\,000},不存在距离恰好为 k\sqrt{k} 的城市,所以每个没放烟花的城市都会被分配数值 11。因此,每种真子集 TT 的爆炸性均为 11,所以答案为 1+1+1=31+1+1=3

首页