#P6898. [ICPC2014 WF] Metal Processing Plant

[ICPC2014 WF] Metal Processing Plant

题目描述

Yulia works for a metal processing plant in Ekaterinburg. This plant processes ores mined in the Ural mountains, extracting precious metals such as chalcopyrite, platinum and gold from the ores. Every month the plant receives nn shipments of unprocessed ore. Yulia needs to partition these shipments into two groups based on their similarity. Then, each group is sent to one of two ore processing buildings of the plant.

To perform this partitioning, Yulia first calculates a numeric distance d(i,j)d(i, j) for each pair of shipments 1in1 \le i \le n and 1jn1 \le j \le n, where the smaller the distance, the more similar the shipments ii and jj are. For a subset S{1,,n}S \subseteq \{ 1, \ldots , n\} of shipments, she then defines the disparity DD of SS as the maximum distance between a pair of shipments in the subset, that is,

D(S)=maxi,jSd(i,j).D(S) = \max _{i, j \in S} d(i, j).

Yulia then partitions the shipments into two subsets AA and BB in such a way that the sum of their disparities D(A)+D(B)D(A) + D(B) is minimized. Your task is to help her find this partitioning.

输入格式

The input consists of a single test case. The first line contains an integer nn (1n2001 \le n \le 200) indicating the number of shipments. The following n1n - 1 lines contain the distances d(i,j)d(i,j). The ithi^{th} of these lines contains nin - i integers and the jthj^{th} integer of that line gives the value of d(i,i+j)d(i, i+j). The distances are symmetric, so d(j,i)=d(i,j)d(j, i) = d(i, j), and the distance of a shipment to itself is 00. All distances are integers between 00 and 10910^9 (inclusive).

输出格式

Display the minimum possible sum of disparities for partitioning the shipments into two groups.

题目大意

题目描述

尤利娅在叶卡捷琳堡的一家金属加工厂工作。该工厂在乌拉尔山脉提取矿石中的铜、铂和金。工厂每月收到 nn 批未经处理的矿石。尤利娅需要对这些货物进行分割为两组。然后它们会分别被送到工厂的两个冶矿塔。

首先,尤利娅对每对货物 i,j(1i,jn)i,j(1\leq i,j\leq n) 给出一个di,jd_{i,j},对于子集 SSD(S)D(S) 定义为 max(i,jS){d(i,j)}\max\limits_{(i,j\in S)}\{d_{(i,j)}\}

然后,尤利娅将货物分成 AABB 两部分,使 D(A)+D(B)D(A)+D(B) 最小。请你帮助她找到划分方法。

输入格式

输入包括多组数据。 对于每组测试数据: 第一行包含一个整数 n(1n200)n(1\leq n\leq 200),表示发货数量。接下来 n1n-1 行每行有 nin-i 个数,第 jj 个数表示 di,i+jd_{i,i+j}。且 dj,i=di,j,di,i=0d_{j,i}=d_{i,j},d_{i,i}=0

输入格式

对于每组测试数据,输出 D(A)+D(B)D(A)+D(B) 的最小值。

5
4 5 0 2
1 3 7
2 0
4

4

7
1 10 5 5 5 5
5 10 5 5 5
100 100 5 5
10 5 5
98 99
3

15

提示

Time limit: 2000 ms, Memory limit: 1048576 kB.

International Collegiate Programming Contest (ACM-ICPC) World Finals 2014