A92961.「BalticOI 2016 Day1」公园

提高+/省选-

官方

通过率:0%

时间限制:2.50s

内存限制:256MB

题目描述

题目译自 BalticOI 2016 Day1 T2「Park」

在 Byteland 的首都,有一个以围墙包裹的矩形公园,其中以圆形表示游客和树。
公园里有四个入口,分别在四个角落(1,2,3,41, 2, 3, 4 分别对应左下、右下、右上、左上)。游客只能从入口进出。
游客可以在他们与公园的两邻边相切的时候进出对应的出口。游客可以在公园里自由活动但不允许与树重叠。
你的任务是为每个游客计算,给定他们进入公园的入口,他们可以从哪个入口离开公园。

输入格式

第一行包含两个整数 nnmm,分别为树的个数和游客的个数。
第二行包含两个整数 wwhh,公园的左下角在 (0,0)(0,0),右上角在 (w,h)(w,h)
接下来 nn 行,每行三个整数 x,yx,yrr,表示有一棵圆心在 (x,y)(x,y) 且半径为 rr 的树。保证树与树之间不会互相重叠。
接下来 mm 行,每行两个整数 rree,表示有一个半径为 rr 的游客从入口 ee 进入。
此外,保证没有树会与每个角落的一个大小为 2k22k^2 的方形区域重叠,kk 表示最大的游客半径。

输出格式

对于每个游客,输出没有空格的一行,表示该游客可以从这几个入口离开,按照升序排列。

输入输出样例

  • 输入#1

    5 3
    16 11
    11 8 1
    6 10 1
    7 3 2
    10 4 1
    15 5 1
    1 1
    2 2
    2 1

    输出#1

    1234
    2
    14

说明/提示

两个物体有重叠定义为它们不止一个公共点。

对于每个子任务,4kw,h1094k \leq w,h \leq 10^9kk 表示最大的游客半径。

子任务 分数 数据范围
1 27 1n2000,m=11 \leq n \leq 2000,m=1
2 31 1n200,1m1051 \leq n \leq 200,1 \leq m \leq 10^5
3 42 1n2000,1m1051 \leq n \leq 2000,1 \leq m \leq 10^5
首页