关注
所以代码只通过了例子,不保证代码能ac #include <iostream>
#include <cmath>
using namespace std;
int dis(int mid_x, int mid_y, int x[], int y[],int start,int end) {
int step = 0;
for (int i=start;i<end;i++){
step += abs(mid_x - x[i]) + abs(mid_y - y[i]);
}
return step;
};
int get_step(int x[], int y[],int start,int end){
int min_x = 1000;
int max_x = 0;
int min_y = 1000;
int max_y = 0;
for (int i=start;i<end;i++){
max_x = max(x[i],max_x);
min_x = min(x[i],min_x);
max_y = max(y[i],max_y);
min_y = min(y[i],min_y);
}
int mid_x = (min_x + max_x)/2;
int mid_y = (min_y + max_y)/2;
int last_mid_x = mid_x+1;
int last_mid_y = mid_y+1;
int min_step=10000;
while(max_x-min_x>=1){
while (max_y-min_y>=1){
if (dis(mid_x,mid_y,x,y,start,end)>dis(mid_x,max_y,x,y,start,end)){
min_y = mid_y;
}else{
max_y = mid_y;
}
min_step = min(dis(mid_x,mid_y,x,y,start,end),dis(mid_x,max_y,x,y,start,end));
last_mid_y = mid_y;
if (last_mid_y==(min_y + max_y)/2){
break;
}
mid_y = (min_y + max_y)/2;
};
if(dis(mid_x,mid_y,x,y,start,end) > dis(max_x,mid_y,x,y,start,end))
min_x = mid_x;
else
max_x = mid_x;
min_step = min(dis(mid_x,mid_y,x,y,start,end) , dis(max_x,mid_y,x,y,start,end));
last_mid_x = mid_x;
if (last_mid_x==(min_x + max_x)/2){
break;
}
mid_x = (min_x + max_x)/2;
}
return min_step;
}
void get_steps(int x[], int y[],int n) {
cout<<0<<' ';
for (int i=2;i<n;i++){
int min_step = 1000;
for(int j=0;j<n-i;j++){
min_step = min(min_step,get_step(x,y,j,j+i));
}
cout<<min_step<<' ';
}
cout<<get_step(x,y,0,n)<<endl;
};
int main() {
int n;
cin >> n;
int x[n], y[n];
for (int j = 0; j < n; j++) {
cin >> x[j];
}
for (int j = 0; j < n; j++) {
cin >> y[j];
}
get_steps(x,y,n);
return 0;
}
查看原帖
点赞 7
相关推荐
牛客热帖
更多
正在热议
更多
# 拿到offer之后,可以做些什么 #
20025次浏览 156人参与
# 硬件开发岗知多少 #
15376次浏览 121人参与
# 乐堡互娱校招 #
16154次浏览 224人参与
# 入职跑路最快的一次经历 #
20500次浏览 144人参与
# ___岗狗都不干,我干! #
9416次浏览 88人参与
# 校招谈薪技巧 #
32960次浏览 468人参与
# 携程求职进展汇总 #
606468次浏览 4505人参与
# 材料转码还有必要吗? #
27137次浏览 143人参与
# 面试时间长是好事吗? #
49658次浏览 378人参与
# 你会为了工作牺牲生活吗? #
39884次浏览 298人参与
# 小米编程考试 #
6245次浏览 97人参与
# 国企秋招,你投了吗? #
6749次浏览 63人参与
# 你在职场中沾染到的“坏”习惯 #
7553次浏览 82人参与
# 华为工作体验 #
227422次浏览 1274人参与
# 如何看待应届生身份? #
166434次浏览 1891人参与
# 如果你有一天可以担任公司的CEO,你会做哪三件事? #
36910次浏览 497人参与
# 材料人的华为红黑体验 #
31778次浏览 178人参与
# 中兴工作体验 #
34769次浏览 298人参与
# 提名点击就挂的公司 #
45588次浏览 231人参与
# 面试被问第一学历差时该怎么回答 #
184392次浏览 1463人参与
# HR问:你期望的薪资是多少?如何回答 #
59401次浏览 617人参与