堆棋子問題

2021-08-07 05:38:52 字數 1613 閱讀 3145

小易將n個棋子擺放在一張無限大的棋盤上。第i個棋子放在第x[i]行y[i]列。同乙個格仔允許放置多個棋子。每一次操作小易可以把乙個棋子拿起並將其移動到原格仔的上、下、左、右的任意乙個格仔中。小易想知道要讓棋盤上出現有乙個格仔中至少有i(1 ≤ i ≤ n)個棋子所需要的最少操作次數.

輸入描述:

輸入包括三行,第一行乙個整數n(1 ≤ n ≤ 50),表示棋子的個數

第二行為n個棋子的橫座標x[i](1 ≤ x[i] ≤ 10^9)

第三行為n個棋子的縱座標y[i](1 ≤ y[i] ≤ 10^9)

輸出描述:

輸出n個整數,第i個表示棋盤上有乙個格仔至少有i個棋子所需要的運算元,以空格分割。行末無空格

如樣例所示:

對於1個棋子: 不需要操作

對於2個棋子: 將前兩個棋子放在(1, 1)中

對於3個棋子: 將前三個棋子放在(2, 1)中

對於4個棋子: 將所有棋子都放在(3, 1)中

示例1

4

1 2 4 9

1 1 1 1

0 1 3 10

錯誤解法(會超記憶體):

class help}}

return;

} newnowlist = new arraylist<>(nowlist);

//而且最大的乙個數是n-m,因為是組合,所以上界停在這裡(只針對第一種情況),所以要判斷一下

int top = 0;

if(k == 1) else

//取出上次排的最後乙個元素,並加1為下乙個元素

for(int i = nowlist.size() > 0 ? nowlist.get(nowlist.size() - 1) + 1 : k - 1; i < top; i++)

} }}public class test

for(int i = 0; i < n; i++)

//挑選出n個格仔的邊界範圍

//a,b代表邊界矩形的左上角座標

int a = integer.max_value;

int b = integer.min_value;

//c,d代表邊界矩形的右下角座標

int c = integer.min_value;

int d = integer.max_value;

for(int i = 0; i < n; i++)

"a:" + a + " b:" + b);

"c:" + c + " d:" + d);

//開始計算結果

res[0] = 0;//根據題意

for(int i = 2; i <= n; i++)

min = math.min(min, tempsum);}}

}min = math.min(min, tempsum);

res[i - 1] = min;

} for(int i = 0; i < n - 1; i++)

system.out.println(res[n - 1]);

in.close();

}}

程式設計題 堆棋子

小易將n個棋子擺放在一張無限大的棋盤上。第i個棋子放在第x i 行y i 列。同乙個格仔允許放置多個棋子。每一次操作小易可以把乙個棋子拿起並將其移動到原格仔的上 下 左 右的任意乙個格仔中。小易想知道要讓棋盤上出現有乙個格仔中至少有i 1 i n 個棋子所需要的最少操作次數.輸入描述 輸入包括三行,...

程式設計題 堆棋子

程式設計題 堆棋子 時間限制 1秒 空間限制 32768k 小易將n個棋子擺放在一張無限大的棋盤上。第i個棋子放在第x i 行y i 列。同乙個格仔允許放置多個棋子。每一次操作小易可以把乙個棋子拿起並將其移動到原格仔的上 下 左 右的任意乙個格仔中。小易想知道要讓棋盤上出現有乙個格仔中至少有i 1 ...

網易筆試題 堆棋子

小易將n個棋子擺放在一張無限大的棋盤上。第i個棋子放在第x i 行y i 列。同乙個格仔允許放置多個棋子。每一次操作小易可以把乙個棋子拿起並將其移動到原格仔的上 下 左 右的任意乙個格仔中。小易想知道要讓棋盤上出現有乙個格仔中至少有i 1 i n 個棋子所需要的最少操作次數.輸入描述 輸入包括三行,...