关注
所以代码只通过了例子,不保证代码能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
相关推荐
点赞 评论 收藏
分享
11-15 08:21
江西理工大学 数据分析师 点赞 评论 收藏
分享
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 为了去实习,我赌上了___ #
13216次浏览 152人参与
# 晒一晒你收到的礼盒 #
87179次浏览 425人参与
# uu们,春招你还来吗? #
5582次浏览 50人参与
# 2025年终总结 #
5545次浏览 116人参与
# 十二月请对我好一点 #
18255次浏览 261人参与
# 父母对你找工作是助力还是阻力? #
9051次浏览 168人参与
# 第一份工作能做外包吗? #
84485次浏览 567人参与
# 哪一瞬间让你觉得“这班不如不上” #
6524次浏览 107人参与
# 一人推荐一个值得做的项目 #
6164次浏览 98人参与
# 高薪高压 vs 低薪wlb,你怎么选? #
6961次浏览 86人参与
# 工作前VS工作后,你的心态变化 #
9132次浏览 128人参与
# 工作中出现了XX情况正常吗 #
23327次浏览 190人参与
# 找工作时的取与舍 #
110011次浏览 828人参与
# 市场营销人求职交流聚集地 #
162470次浏览 1212人参与
# 实习打杂,要跑路吗 #
50264次浏览 320人参与
# 公司福利里最没用的一项是啥 #
4659次浏览 83人参与
# 回顾今年你干过的最“勇”的一件事 #
9514次浏览 132人参与
# 非技术er求职现状 #
120402次浏览 753人参与
# 工作两年,想和老板谈涨薪怎么说 #
37148次浏览 169人参与
# 25届非技术实习投递记录 #
139629次浏览 1005人参与
