小易將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如樣例所示:
對於1個棋子: 不需要操作
對於2個棋子: 將前兩個棋子放在(1, 1)中
對於3個棋子: 將前三個棋子放在(2, 1)中
對於4個棋子: 將所有棋子都放在(3, 1)中
41 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 個棋子所需要的最少操作次數.輸入描述 輸入包括三行,...