Codeforces Round #352 (Div. 2) C. Recycling Bottles
来源:互联网 发布:淘宝刷单一单的价格 编辑:程序博客网 时间:2024/06/05 03:21
【题意】有两个人A,B在一个二维平面上捡瓶子放到垃圾箱里,每个人从从初始位置出发,一次只能选择一个瓶子去捡,然后去垃圾箱,再去捡瓶子。。。也可以中途不捡了,给出A,B,垃圾箱和n个瓶子的坐标,求两个人捡完瓶子要的最短距离。
【分析】把距离都求出来,再贪心找到最小距离就好了
【Trick】见代码吧。
【AC代码】
#include <bits/stdc++.h>using namespace std;const int maxn = 100003;struct node{ int id; double val; node(){} node(int id,double val):id(id),val(val){} bool operator<(const node &rhs)const{ return val<rhs.val; }}a[maxn],b[maxn];double x[maxn],y[maxn];double get_dis(double x1,double y1,double x2,double y2){ return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));}double ax,ay,bx,by,tx,ty;int n;int main(){ scanf("%lf%lf%lf%lf%lf%lf",&ax,&ay,&bx,&by,&tx,&ty); scanf("%d",&n); for(int i=1; i<=n; i++) cin>>x[i]>>y[i]; for(int i=1; i<=n; i++){ a[i].id=i; a[i].val = get_dis(x[i],y[i],ax,ay)-get_dis(x[i],y[i],tx,ty); } sort(a+1,a+n+1); //Init for(int i=1; i<=n; i++){ b[i].id=i; b[i].val = get_dis(x[i],y[i],bx,by)-get_dis(x[i],y[i],tx,ty); } sort(b+1,b+n+1); double ans = 0; for(int i=1; i<=n; i++) ans+=2.00*get_dis(x[i],y[i],tx,ty);// cout<<ans<<endl; double temp = ans; a[0]=node{0,0}; b[0]=node{0,0}; ans = min(ans+a[1].val,ans+b[1].val); //本题的Trick点 //必须要有一个人动,才能捡完垃圾 //之前循环里面,有可能ans就是最小的,就一直更新不了,这样就代表没人动,是不行的 for(int ii=0; ii<3; ii++){//A动B不动 for(int jj=0; jj<3; jj++){ if(ii==0&&jj==0)continue; if(a[ii].id==b[jj].id) continue; ans = min(ans,temp+a[ii].val+b[jj].val); } } printf("%.8f\n",ans); return 0;}
0 0
- Codeforces 672 C. Recycling Bottles(Codeforces Round #352 (Div. 2))
- Codeforces Round #352 (Div. 2) C. Recycling Bottles
- Codeforces Round #352 (Div. 2) C - Recycling Bottles
- Codeforces Round #352 (Div. 2)C. Recycling Bottles
- Codeforces Round #352 (Div. 2) C. Recycling Bottles
- Codeforces Round #352 (Div. 2) C. Recycling Bottles
- Codeforces Round #352 (Div. 2) C. Recycling Bottles
- Codeforces Round #352 (Div. 2) C. Recycling Bottles (几何)
- Codeforces Round #352 (Div. 2) C. Recycling Bottles __ geometry, greedy and pretreat
- Codeforces Round #352 (Div. 1) A. Recycling Bottles
- Codeforces Round #352 (Div. 1) A. Recycling Bottles 暴力
- Codeforces #352 Recycling Bottles
- Codeforces #352 Div2 C Recycling Bottles
- codeforces#352-C - Recycling Bottles-贪心
- codeforces 672C. Recycling Bottles
- CodeForces-672C-Recycling Bottles
- codeforces 672C Recycling Bottles
- CodeForces Round 352——Recycling Bottles & Robin Hood
- ReentrantLock 源码
- Keepalived实现双机热备
- FPGA:下一代机器人感知处理器
- LintCode:丢失的第一个正整数
- Raspberry Pi如何使用MPU6050
- Codeforces Round #352 (Div. 2) C. Recycling Bottles
- mysql 5.7免安装版步骤
- 怎么在linux下用vim编写一个C程序
- 测试一下
- 《Spark 官方文档》Spark调优
- 通过js 向table添加或修改row及cell
- windows与linux双系统,删除linux分区后,开机进入grub resuce提示符的问题
- poj之旅——1017
- JDBC高级编程。分页