关注
所以代码只通过了例子,不保证代码能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
相关推荐
二本牛马:大佬又让我看见了希望
点赞 评论 收藏
分享
双非25想找富婆不想打工:哦,这该死的伦敦腔,我敢打赌,你简直是个天才,如果我有offer的话,我一定用offer狠狠的打在你的脸上
点赞 评论 收藏
分享
牛客热帖
正在热议
# 25届秋招总结 #
459237次浏览 4700人参与
# 如何排解工作中的焦虑 #
72800次浏览 1013人参与
# 地方国企笔面经互助 #
8579次浏览 18人参与
# 同bg的你秋招战况如何? #
86824次浏览 636人参与
# 找工作时遇到的神仙HR #
566887次浏览 3858人参与
# 你上一次加班是什么时候? #
23154次浏览 185人参与
# 选了这个offer,你有没有后悔? #
414850次浏览 3147人参与
# 晒一晒我的offer #
10019746次浏览 106317人参与
# 比亚迪工作体验 #
45403次浏览 214人参与
# 设计人的面试记录 #
75172次浏览 962人参与
# 你今年的平均薪资是多少? #
77662次浏览 375人参与
# 虾皮求职进展汇总 #
127399次浏览 934人参与
# 实习,投递多份简历没人回复怎么办 #
2462264次浏览 34911人参与
# 非技术岗薪资爆料 #
201060次浏览 1726人参与
# 如果公司给你放一天假,你会怎么度过? #
5050次浏览 65人参与
# 你的秋招进展怎么样了 #
1717616次浏览 24784人参与
# 什么专业适合考公 #
15001次浏览 116人参与
# 实习必须要去大厂吗? #
56569次浏览 967人参与
# 现在还是0offer,延毕还是备考 #
827353次浏览 6928人参与
# 总结:哪家公司面试体验感最好 #
20462次浏览 92人参与