308857: CF1585C. Minimize Distance

Memory Limit:256 MB Time Limit:1 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

Minimize Distance

题意翻译

每组数据:n,k 1个长度为n的数组 数组中的一个元素 $a_i$ 代表在数轴上 $a_i$ 的位置有一个仓库。 刚开始你位于 0 ,手上有n个货物,要把他们放到每个仓库中,但是每次你最多能拿k个货物,把他们放到仓库之后你要回到原点0拿取新的货物。最后一趟不用返回。 问题是你最少需要走多远能把所有物品放进仓库。

题目描述

A total of $ n $ depots are located on a number line. Depot $ i $ lies at the point $ x_i $ for $ 1 \le i \le n $ . You are a salesman with $ n $ bags of goods, attempting to deliver one bag to each of the $ n $ depots. You and the $ n $ bags are initially at the origin $ 0 $ . You can carry up to $ k $ bags at a time. You must collect the required number of goods from the origin, deliver them to the respective depots, and then return to the origin to collect your next batch of goods. Calculate the minimum distance you need to cover to deliver all the bags of goods to the depots. You do not have to return to the origin after you have delivered all the bags.

输入输出格式

输入格式


Each test contains multiple test cases. The first line contains the number of test cases $ t $ ( $ 1 \le t \le 10\,500 $ ). Description of the test cases follows. The first line of each test case contains two integers $ n $ and $ k $ ( $ 1 \le k \le n \le 2 \cdot 10^5 $ ). The second line of each test case contains $ n $ integers $ x_1, x_2, \ldots, x_n $ ( $ -10^9 \le x_i \le 10^9 $ ). It is possible that some depots share the same position. It is guaranteed that the sum of $ n $ over all test cases does not exceed $ 2 \cdot 10^5 $ .

输出格式


For each test case, output a single integer denoting the minimum distance you need to cover to deliver all the bags of goods to the depots.

输入输出样例

输入样例 #1

4
5 1
1 2 3 4 5
9 3
-5 -10 -15 6 5 8 3 7 4
5 3
2 2 3 3 3
4 2
1000000000 1000000000 1000000000 1000000000

输出样例 #1

25
41
7
3000000000

说明

In the first test case, you can carry only one bag at a time. Thus, the following is a solution sequence that gives a minimum travel distance: $ 0 \to 2 \to 0 \to 4 \to 0 \to 3 \to 0 \to 1 \to 0 \to 5 $ , where each $ 0 $ means you go the origin and grab one bag, and each positive integer means you deliver the bag to a depot at this coordinate, giving a total distance of $ 25 $ units. It must be noted that there are other sequences that give the same distance. In the second test case, you can follow the following sequence, among multiple such sequences, to travel minimum distance: $ 0 \to 6 \to 8 \to 7 \to 0 \to 5 \to 4 \to 3 \to 0 \to (-5) \to (-10) \to (-15) $ , with distance $ 41 $ . It can be shown that $ 41 $ is the optimal distance for this test case.

Input

题意翻译

每组数据:n,k 1个长度为n的数组 数组中的一个元素 $a_i$ 代表在数轴上 $a_i$ 的位置有一个仓库。 刚开始你位于 0 ,手上有n个货物,要把他们放到每个仓库中,但是每次你最多能拿k个货物,把他们放到仓库之后你要回到原点0拿取新的货物。最后一趟不用返回。 问题是你最少需要走多远能把所有物品放进仓库。

加入题单

算法标签: