luogu#P7639. [BalticOI 2006 Day 1] COUNTRIES

[BalticOI 2006 Day 1] COUNTRIES

题目背景

任何一个国家都是由弱小而拼搏斗争逐渐强大崛起的。

题目描述

考虑地区的二维地图,在这张地图上有 nn 个城市。每个城市 ii 在地图上都有一个独特的坐标(xix_i,yiy_i)。每个城市在一个将军的指挥下有 sis_i 个士兵。
城市 ii 对另一个位置(xx,yy)的威慑为 sis_i 除于它和(xx,yy)间距离的平方。这就好像城市 ii 中的大量士兵对它周围所有地图位置施加了威慑。如果城市 jj 对(xix_i,yiy_i)的城市 ii 的威慑超过其士兵数 sis_i:城市 jj 可以派遣足够的士兵前去制服保卫城市 ii 的士兵,那么城市 ii 就被城市 jj 所威胁。如果城市 ii 没有受到任何其他城市 jj 的威胁,那么心存感激的市民将选出其无敌的将军作为他们的国王,并将他们的城市变成他的王国的首都。
另一方面,如果一些城市 jj 对(xix_i,yiy_i)的城市 ii 的威胁比另一个城市 kk 对城市 ii 的威胁更具威慑,那么城市 ii 的居民别无选择:城市 ii 只能向城市 jj 投降。从今以后,城市 ii 必须服从城市 jj 所服从的首都;然而城市 ii 的士兵并没有加入城市 jj 或其首都的军队。除此之外,城市 ii 会因为 jj 和 kk 两个对它具有同等威胁的城市之间相互防备而得救:如果其中一个城市攻击并征服城市 ii,那么另一个城市将会前来攻击并战胜先前刚战斗完而疲惫不堪的攻击方士兵。但这种情况下,城市 ii 的居民们将不再选举他们的将军为他们的国王,因为他未能履行他的职责保护城市免受威胁。因此,他们必须把他们的城市变成一个民主国家的首都。
你的任务是编写一个程序,将地图上的城市信息作为输入,并为每个城市 ii 输出三种结果之一:

  • 它是一个王国的首都。
  • 它是一个民主国家的首都。
  • 它服从城市 jj 作为它的首都。

输入格式

第一行由一个整数 nn 组成,表示城市数。接下来的 nn 行给出这 nn 个城市的信息,每行给出一个城市的。第 i+1i+1 行以三个整数 xix_iyiy_isis_i 表示城市 ii 的信息,这三个整数由单个空格字符分隔。

输出格式

输出由 nn 行组成,其中第 ii 行由城市 ii 的结果组成:

  • 字母 K\texttt{K} 表示城市 ii 是一个王国的首都。
  • 字母 D\texttt{D} 表示城市 ii 是一个民主国家的首都。
  • 正整数 jj 表示城市 ii 不得不投降而服从其首都的城市 jj
5
2 5 14
2 3 2
3 2 7
1 1 2
2 1 3
K
D
K
3
3

提示

数据规模与约定

对于 100%100 \% 的数据,1n10001 \le n \le 10000xi,yi,si10000 \le x_i,y_i,s_i \le 10001jn1 \le j \le n

样例说明

考虑以下地图,其中每个点代表一个城市,上面给出了它的士兵数量:
TuLi
也就是说,位置(33,22)上的城市 33 是一个王国的首都,它还包括位置(11,11)上的城市 44 和位置(22,11)上的城市 55。另一方面,位于位置(22,55)的城市 11 自己形成了一个王国,而位于位置(22,33)的城市 22 自己形成了一个民主国家。

题目说明

来源于 Baltic Olympiad in Informatics 2006Day 1:Countries
由 @求学的企鹅 翻译整理。