Agc019_C Fountain Walk
题目大意
给定网格图上起点和终点每个格子是长为$100$米的正方形,你可以沿着线走。
平面上还有若干个关键点,以每个关键点为圆心,$10$为半径画圆,表示不能进入圆内的线,但是可以从圆周上走,求起点到终点的最短距离。
保证任意两个关键点不在同一条水平或竖直的线上。
题解
先通过翻转网格图使得起点$S$在终点$Y$的左下方,由于有任意两两关键点不在同一水平竖直的线上,通过简单计算发现,我们只可能往右或往上冲着最终的终点走。
随意我们只需要横纵坐标都在起点终点之间的关键点即可。
对于一个关键点,如果经过它转$90°$,那么路程的长度就会减少,如果绕过半圆继续直走,那么路程长度就会增加。
我们贪心取关键点。由于起点在左下方,终点在右上方,每次向右上方走,那么最终经过的关键点一定是一个上升的序列。
我们只需要求这个上升的序列的长度即可。
答案等于起点终点的曼哈顿距离$-$经过关键点的数量$\times$绕$90$度省去的路程。
注意,当最长上升子序列的长度达到$\min\{Y_T-Y_S+1,X_T-X_S+1\}$时,说明至少绕过一个关键点的半圆,需要特判。
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#define LL long long
#define M 200020
using namespace std;
namespace IO{
const int BS=(1<<20)+5; int Top=0;
char Buffer[BS],OT[BS],*OS=OT,*HD,*TL,SS[20]; const char *fin=OT+BS-1;
char Getchar(){if(HD==TL){TL=(HD=Buffer)+fread(Buffer,1,BS,stdin);} return (HD==TL)?EOF:*HD++;}
void flush(){fwrite(OT,1,OS-OT,stdout);}
void Putchar(char c){*OS++ =c;if(OS==fin)flush(),OS=OT;}
void write(int x){
if(!x){Putchar('0');return;} if(x<0) x=-x,Putchar('-');
while(x) SS[++Top]=x%10,x/=10;
while(Top) Putchar(SS[Top]+'0'),--Top;
}
int read(){
int nm=0,fh=1; char cw=Getchar();
for(;!isdigit(cw);cw=Getchar()) if(cw=='-') fh=-fh;
for(;isdigit(cw);cw=Getchar()) nm=nm*10+(cw-'0');
return nm*fh;
}
}
using namespace IO;
const double D=11.4159265358979323846264338328;
const double K=-4.2920367320510338076867830836;
int n,m,maxy,sx,sy,ex,ey,tot,c[M],pos[M],now; double ans;
struct pot{
int X,Y; void gtin(){X=read(),Y=read(),maxy=max(maxy,Y+1);}
bool ft(){return X>=sx&&X<=ex&&Y>=sy&&Y<=ey;}
bool operator <(const pot&ot)const{return X<ot.X;}
}p[M],t[M];
int main(){
sx=read(),sy=read(),ex=read(),ey=read(),maxy=max(sy,ey);
if(sx>ex) swap(sx,ex),swap(sy,ey); n=read();
for(int i=1;i<=n;i++) p[i].gtin();
if(sy>ey){
for(int i=1;i<=n;i++) p[i].Y=maxy-p[i].Y;
sy=maxy-sy,ey=maxy-ey;
} sort(p+1,p+n+1),ans=(ey+ex-sy-sx)*100.0;
for(int i=1;i<=n;i++) if(p[i].ft()) t[++tot]=p[i];
memset(c,0x3f,sizeof(c)),c[0]=now=0;
for(int i=1;i<=tot;i++){
int l=1,r=now,md,res=0;
while(l<=r){md=((r+l)>>1);if(c[md]<t[i].Y) res=md,l=md+1;else r=md-1;}
if(res==now) now++; c[res+1]=min(c[res+1],t[i].Y);
}
if(now<=ex-sx&&now<=ey-sy) ans+=now*K;
else ans+=(now-1)*K+D; printf("%.13lf\n",ans);
return 0;
}
Agc019_C Fountain Walk的更多相关文章
- [AtCoder 2702]Fountain Walk - LIS
Problem Statement In the city of Nevermore, there are 108 streets and 108 avenues, both numbered fro ...
- 【agc019C】Fountain Walk
Portal --> agc019C Description 有一个\(10^8*10^8\)的网格图,一格距离为\(100\),第\(x\)条竖线和第\(y\)条横线的交点记为\((x,y)\ ...
- 【AtCoder】AGC019
A - Ice Tea Store 算一下每种零售最少的钱就行,然后优先买2,零头买1 #include <bits/stdc++.h> #define fi first #define ...
- python os.walk()
os.walk()返回三个参数:os.walk(dirpath,dirnames,filenames) for dirpath,dirnames,filenames in os.walk(): 返回d ...
- LYDSY模拟赛day1 Walk
/* 依旧考虑新增 2^20 个点. i 只需要向 i 去掉某一位的 1 的点连边. 这样一来图的边数就被压缩到了 20 · 2^20 + 2n + m,然后 BFS 求出 1 到每个点的最短路即可. ...
- How Google TestsSoftware - Crawl, walk, run.
One of the key ways Google achievesgood results with fewer testers than many companies is that we ra ...
- poj[3093]Margaritas On River Walk
Description One of the more popular activities in San Antonio is to enjoy margaritas in the park alo ...
- os.walk()
os.walk() 方法用于通过在目录树种游走输出在目录中的文件名,向上或者向下. walk()方法语法格式如下: os.walk(top[, topdown=True[, onerror=None[ ...
- 精品素材:WALK & RIDE 单页网站模板下载
今天,很高兴能向大家分享一个响应式的,简约风格的 HTML5 单页网站模板.Walk & Ride 这款单页网站模板是现代风格的网页模板,简洁干净,像素完美,特别适合用于推广移动 APP 应用 ...
随机推荐
- 20160418 while,switch,do..while的使用
9 一.While循环 示例:求100以内所有数的和 Int i=1;//初始条件 Int sum=0; While(i<=100)//循环条件 { Sum+=i;//循环体 i++;//状态改 ...
- openstack ha 部署
一.控制节点架构如下图: 二.初始化环境: 1.配置IP地址: 1.节点1:ip addr add dev eth0 192.168.142.110/24 echo 'ip addr add dev ...
- python有哪些好的学习资料或者博客?
推荐Full Stack Python 有各种python资源汇总,从基础入门到各种框架web应用开发和部署,再到高级的ORM.Docker都有.以下是Full Stack Python 上总结的一些 ...
- 014_HDFS存储架构、架构可靠性分析、副本放置策略、各组件之间的关系
1.HDFS存储架构
- Oracle 9i Unix Manager
在Unix上被迫终止ORACLE进程时,必须做以下事情: (1) 杀掉所有Oracle进程. ps -ef|grep $ORACLE_SID|grep -v grep|awk '{print $ ...
- ETL应用:使用Pro*C实现文件抽取的方法
/******************************************* ***** 函数功能 : ***** 抽取数据库记录 ***** ********************** ...
- 【HackerRank】Gem Stones
Gem Stones John has discovered various rocks. Each rock is composed of various elements, and each el ...
- 4.2《深入理解计算机系统》笔记(五)并发、多进程和多线程【Final】
该书中第11章是写web服务器的搭建,无奈对web还比较陌生.还没有搞明白. 这些所谓的并发,其实都是操作系统做的事情,比如,多进程是操作系统fork函数实现的.I/O多路复用需要内核挂起进程.多线程 ...
- Objective-C与Swift的混合编程
Swift 被设计用来无缝兼容 Cocoa 和 Objective-C .在 Swift 中,你可以使用 Objective-C 的 API(包括系统框架和你自定义的代码),你也可以在 Objecti ...
- Spring-data-jpa常用方法