关注
所以代码只通过了例子,不保证代码能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
相关推荐
点赞 评论 收藏
分享
01-14 17:06
哈尔滨工程大学 Java 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 牛客吐槽大会 #
14242次浏览 207人参与
# 实习,不懂就问 #
159013次浏览 1405人参与
# 晒晒你司的新年福利 #
762次浏览 20人参与
# 国企秋招,你投了吗? #
58773次浏览 376人参与
# 程序员能干到多少岁? #
761次浏览 23人参与
# 硬件/芯片公司工作体验 #
146808次浏览 960人参与
# 软开人,秋招你打算投哪些公司呢 #
178262次浏览 1352人参与
# 硬件人秋招进展 #
269385次浏览 3983人参与
# 毕业后不工作的日子里我在做什么 #
232876次浏览 1691人参与
# 帆软软件工作体验 #
11323次浏览 55人参与
# 运营人求职交流聚集地 #
208568次浏览 1091人参与
# 你觉得实习能学到东西吗 #
134851次浏览 1453人参与
# 第一份工作应该只看薪资吗 #
233885次浏览 1855人参与
# 电信求职进展汇总 #
39762次浏览 197人参与
# 关于春招你都做了哪些准备? #
125847次浏览 717人参与
# 快手工作体验 #
301801次浏览 2904人参与
# AI求职实录 #
19550次浏览 443人参与
# 今年春招是金一银二嘛? #
33315次浏览 313人参与
# 没关系,至少我的__很曼妙 #
14478次浏览 245人参与
# 实习打杂,要跑路吗 #
58327次浏览 340人参与
