Submission #1545706
Source Code Expand
#include <algorithm>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <cmath>
#define RG register
#define il inline
#define iter iterator
#define ls (node<<1)
#define rs (node<<1|1)
#define Max(a,b) ((a)>(b)?(a):(b))
#define Min(a,b) ((a)<(b)?(a):(b))
using namespace std;
typedef long double ld;
const int N=200005;
int n=0,xl,xr,yl,yr,m;ld f[N];
ld inf=2e15;
struct node{
int x,y;
bool operator <(const node &pp)const{
if(x!=pp.x)return x<pp.x;
return y<pp.x;
}
}a[N];
ld pi=acos(-1.0),p1=5*pi,p2=10*pi,Tree[N<<2];int b[N];
void upd(int node){
Tree[node]=Min(Tree[ls],Tree[rs]);
}
void updata(int l,int r,int node,int sa,ld to){
if(l>sa || r<sa)return ;
if(l==r){
if(Tree[node]>to)Tree[node]=to;
return ;
}
int mid=(l+r)>>1;
updata(l,mid,ls,sa,to);updata(mid+1,r,rs,sa,to);
upd(node);
}
ld query(int l,int r,int node,int sa,int se){
if(l>se || r<sa)return inf;
if(sa<=l && r<=se)return Tree[node];
int mid=(l+r)>>1;
ld q1=query(l,mid,ls,sa,se),q2=query(mid+1,r,rs,sa,se);
upd(node);
return Min(q1,q2);
}
void work()
{
scanf("%d%d%d%d",&xl,&yl,&xr,&yr);
scanf("%d",&m);
if(xl>xr){
swap(xl,xr);swap(yl,yr);
}
a[++n].x=xl;a[n].y=yl;
int x,y;
for(int i=1;i<=m;i++){
scanf("%d%d",&x,&y);
if(x>=xl && x<=xr && y>=Min(yl,yr) && y<=Max(yl,yr)){
a[++n].x=x;a[n].y=y;
}
}
a[++n].x=xr;a[n].y=yr;
int num=0;
for(int i=1;i<=n;i++){
b[++num]=a[i].y;
}
sort(b+1,b+num+1);
int tot=unique(b+1,b+num+1)-b-1;
for(int i=1;i<=n;i++)a[i].y=lower_bound(b+1,b+tot+1,a[i].y)-b;
sort(a+1,a+n+1);
if(yl<=yr){
for(int i=1;i<=n;i++)f[i]=inf;
ld ans=100*fabs(yr-yl)+100*fabs(xr-xl);ld tmp;
updata(1,n,1,1,0);
for(int i=2;i<n;i++){
tmp=query(1,n,1,1,a[i].y-1)+p1-20.0;
if(tmp<f[i])f[i]=tmp;
tmp=query(1,n,1,a[i].y,a[i].y)+p2-20.0;
if(tmp<f[i])f[i]=tmp;
updata(1,n,1,a[i].y,f[i]);
}
for(int i=2;i<=n;i++){
if(a[n].y>=a[i].y)
f[n]=min(f[n],f[i]);
}
if(n>2)ans+=f[n];
printf("%.16Lf\n",ans);
}
else{
for(int i=1;i<=n;i++)f[i]=inf;
ld ans=100*fabs(yr-yl)+100*fabs(xr-xl);ld tmp;
updata(1,n,1,1,0);
for(int i=2;i<n;i++){
tmp=query(1,n,1,a[i].y+1,n)+p1-20.0;
if(tmp<f[i])f[i]=tmp;
tmp=query(1,n,1,a[i].y,a[i].y)+p2-20.0;
if(tmp<f[i])f[i]=tmp;
updata(1,n,1,a[i].y,f[i]);
}
for(int i=2;i<=n;i++){
if(a[n].y<=a[i].y)
f[n]=min(f[n],f[i]);
}
if(n>2)ans+=f[n];
printf("%.16Lf\n",ans);
}
}
int main()
{
work();
return 0;
}
Submission Info
| Submission Time |
|
| Task |
C - Fountain Walk |
| User |
Yuao_2001 |
| Language |
C++14 (GCC 5.4.1) |
| Score |
0 |
| Code Size |
2571 Byte |
| Status |
WA |
| Exec Time |
275 ms |
| Memory |
16128 KiB |
Compile Error
./Main.cpp: In function ‘void work()’:
./Main.cpp:50:35: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
scanf("%d%d%d%d",&xl,&yl,&xr,&yr);
^
./Main.cpp:51:16: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
scanf("%d",&m);
^
./Main.cpp:58:22: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
scanf("%d%d",&x,&y);
^
Judge Result
| Set Name |
Sample |
All |
| Score / Max Score |
0 / 0 |
0 / 900 |
| Status |
|
|
| Set Name |
Test Cases |
| Sample |
sample_01.txt, sample_02.txt, sample_03.txt |
| All |
sample_01.txt, sample_02.txt, sample_03.txt, sample_01.txt, sample_02.txt, sample_03.txt, subtask_1_01.txt, subtask_1_02.txt, subtask_1_03.txt, subtask_1_04.txt, subtask_1_05.txt, subtask_1_06.txt, subtask_1_07.txt, subtask_1_08.txt, subtask_1_09.txt, subtask_1_10.txt, subtask_1_11.txt, subtask_1_12.txt, subtask_1_13.txt, subtask_1_14.txt, subtask_1_15.txt, subtask_1_16.txt, subtask_1_17.txt, subtask_1_18.txt, subtask_1_19.txt, subtask_1_20.txt, subtask_1_21.txt, subtask_1_22.txt, subtask_1_23.txt, subtask_1_24.txt, subtask_1_25.txt, subtask_1_26.txt, subtask_1_27.txt, subtask_1_28.txt, subtask_1_29.txt, subtask_1_30.txt, subtask_1_31.txt, subtask_1_32.txt, subtask_1_33.txt, subtask_1_34.txt, subtask_1_35.txt, subtask_1_36.txt, subtask_1_37.txt, subtask_1_38.txt, subtask_1_39.txt, subtask_1_40.txt, subtask_1_41.txt |
| Case Name |
Status |
Exec Time |
Memory |
| sample_01.txt |
AC |
2 ms |
4352 KiB |
| sample_02.txt |
AC |
2 ms |
4352 KiB |
| sample_03.txt |
AC |
2 ms |
4352 KiB |
| subtask_1_01.txt |
AC |
2 ms |
4352 KiB |
| subtask_1_02.txt |
AC |
2 ms |
4352 KiB |
| subtask_1_03.txt |
AC |
2 ms |
4352 KiB |
| subtask_1_04.txt |
AC |
2 ms |
4352 KiB |
| subtask_1_05.txt |
AC |
2 ms |
4352 KiB |
| subtask_1_06.txt |
AC |
2 ms |
4352 KiB |
| subtask_1_07.txt |
AC |
2 ms |
4352 KiB |
| subtask_1_08.txt |
AC |
2 ms |
4352 KiB |
| subtask_1_09.txt |
WA |
15 ms |
4352 KiB |
| subtask_1_10.txt |
WA |
30 ms |
4352 KiB |
| subtask_1_11.txt |
WA |
9 ms |
4352 KiB |
| subtask_1_12.txt |
WA |
245 ms |
16128 KiB |
| subtask_1_13.txt |
AC |
32 ms |
4352 KiB |
| subtask_1_14.txt |
WA |
16 ms |
4352 KiB |
| subtask_1_15.txt |
WA |
8 ms |
4352 KiB |
| subtask_1_16.txt |
WA |
244 ms |
16128 KiB |
| subtask_1_17.txt |
WA |
27 ms |
4352 KiB |
| subtask_1_18.txt |
AC |
22 ms |
4352 KiB |
| subtask_1_19.txt |
WA |
22 ms |
4352 KiB |
| subtask_1_20.txt |
WA |
242 ms |
16128 KiB |
| subtask_1_21.txt |
WA |
245 ms |
16128 KiB |
| subtask_1_22.txt |
AC |
246 ms |
16128 KiB |
| subtask_1_23.txt |
WA |
246 ms |
16128 KiB |
| subtask_1_24.txt |
AC |
2 ms |
4352 KiB |
| subtask_1_25.txt |
AC |
2 ms |
4352 KiB |
| subtask_1_26.txt |
AC |
2 ms |
4352 KiB |
| subtask_1_27.txt |
AC |
2 ms |
4352 KiB |
| subtask_1_28.txt |
AC |
42 ms |
4608 KiB |
| subtask_1_29.txt |
AC |
45 ms |
4608 KiB |
| subtask_1_30.txt |
AC |
275 ms |
16128 KiB |
| subtask_1_31.txt |
AC |
219 ms |
16128 KiB |
| subtask_1_32.txt |
AC |
205 ms |
16128 KiB |
| subtask_1_33.txt |
WA |
206 ms |
16128 KiB |
| subtask_1_34.txt |
AC |
208 ms |
16128 KiB |
| subtask_1_35.txt |
AC |
215 ms |
16128 KiB |
| subtask_1_36.txt |
AC |
257 ms |
16128 KiB |
| subtask_1_37.txt |
AC |
222 ms |
16128 KiB |
| subtask_1_38.txt |
AC |
224 ms |
16128 KiB |
| subtask_1_39.txt |
AC |
219 ms |
16128 KiB |
| subtask_1_40.txt |
AC |
216 ms |
16128 KiB |
| subtask_1_41.txt |
AC |
216 ms |
16128 KiB |