Problem Statement
In the city of Nevermore, there are 108 streets and 108 avenues, both numbered from0 to 108−1. All streets run straight from west to east, and all avenues run straight from south to north. The distance between neighboring streets and between neighboring avenues is exactly 100 meters.
Every street intersects every avenue. Every intersection can be described by pair(x,y), where x is avenue ID and y is street ID.
There are N fountains in the city, situated at intersections (Xi,Yi). Unlike normal intersections, there's a circle with radius 10 meters centered at the intersection, and there are no road parts inside this circle.
The picture below shows an example of how a part of the city with roads and fountains may look like.
City governors don't like encountering more than one fountain while moving along the same road. Therefore, every street contains at most one fountain on it, as well as every avenue.
Citizens can move along streets, avenues and fountain perimeters. What is the shortest distance one needs to cover in order to get from intersection (x1,y1) to intersection (x2,y2)?
Constraints
- 0≤x1,y1,x2,y2<108
- 1≤N≤200,000
- 0≤Xi,Yi<108
- Xi≠Xj for i≠j
- Yi≠Yj for i≠j
- Intersections (x1,y1) and (x2,y2) are different and don't contain fountains.
- All input values are integers.
Input
Input is given from Standard Input in the following format:
x1 y1 x2 y2 N X1 Y1 X2 Y2 : XN YN
Output
Print the shortest possible distance one needs to cover in order to get from intersection (x1,y1) to intersection (x2,y2), in meters. Your answer will be considered correct if its absolute or relative error doesn't exceed 10−11.
Sample Input 1
1 1 6 5 3 3 2 5 3 2 4
Sample Output 1
891.415926535897938
One possible shortest path is shown on the picture below. The path starts at the blue point, finishes at the purple point and follows along the red line.
Sample Input 2
3 5 6 4 3 3 2 5 3 2 4
Sample Output 2
400.000000000000000
Sample Input 3
4 2 2 2 3 3 2 5 3 2 4
Sample Output 3
211.415926535897938
愚人节赛的第二题(滑稽)。

#include<cstdio> #include<cstring> #include<algorithm> #include<cmath> #define y1 Y1 using namespace std; const int maxn=200005,inf=1e8; const double qarc=acos(-1)*5.0; int n,cnt,x1,x2,y1,y2; int f[maxn],g[maxn],b[maxn]; struct p{int x,y;}a[maxn]; inline int read(){ int x=0,f=1;char ch=getchar(); for(;ch<'0'||ch>'9';f=ch=='-'?-1:1,ch=getchar()); for(;ch>='0'&&ch<='9';x=x*10+ch-48,ch=getchar()); return x*f; } bool cmp(p a,p b){return a.x<b.x;} int main(){ x1=read();y1=read();x2=read();y2=read();n=read(); for(int i=1;i<=n;i++)a[i].x=read(),a[i].y=read(); if(x1>x2){ x1=inf-x1;x2=inf-x2; for(int i=1;i<=n;i++)a[i].x=inf-a[i].x; } if(y1>y2){ y1=inf-y1;y2=inf-y2; for(int i=1;i<=n;i++)a[i].y=inf-a[i].y; } sort(a+1,a+n+1,cmp); int tot=0,ans1=0; for(int i=1;i<=n;i++) if(a[i].x>=x1&&a[i].x<=x2&&a[i].y>=y1&&a[i].y<=y2) b[++tot]=a[i].y; for(int i=1;i<=tot;i++){ f[i]=lower_bound(g+1,g+ans1+1,b[i])-g; if(f[i]>ans1)ans1=f[i],g[ans1]=b[i]; else g[f[i]]=min(g[f[i]],b[i]); } double ans=(double)(x2+y2-x1-y1)*100.0; ans-=ans1*(20-qarc); if(ans1==min(y2-y1+1,x2-x1+1))ans+=qarc; printf("%.15lf",ans); return 0; }