AtCoder Beginner Contest 356 G. Freestyle(凸包+二分)

题目

思路来源

quality代码

题解

对n个泳姿点(ai,bi)建凸包,实际上是一个上凸壳,

对于询问(ci,di)来说,抽象画一下这个图,箭头方向表示询问向量

按x轴排增序,并且使得后面的y不小于前面的y,因为总可以多耗费体力达到相同的米数

新增一个点(0,0),新增一个点(1e9+1,y),其纵坐标与最后一个点纵坐标相同

对于询问的向量,求它与上凸壳的交点,显然用这个方向的向量是最优的

1. 如果询问的向量在上凸壳第一个点逆时针方向,无解

2. 如果与上凸壳有交点,

显然这个封闭图形内的点都是可以用各种泳姿1s凑出来的,那么交点方向最优,

只需看(ci,di)中的di,是交点处的纵坐标的几倍即可,答案即为这个倍数

3. 如果向量与竖直的这条边有交点,那么最后相当于多耗费体力的情况下1s也可以跑这么多米

那么,两条直线还是有交点的,只是向量与水平直线的交点,

实际用的仍然是交点这个向量,只是实际的含义是y相同的情况下多耗费了体力

然后qls的二分写的就很妙,统一了这三种情况,以及交点恰好是凸包的一个点的情况

我写的就很不优雅,需要讨论三种情况,判断l=0,l=n-1

代码1(qls)

#include<bits/stdc++.h>
#include<iostream>
using namespace std;
typedef long long ll;
typedef long double db;
struct Point
{ll x,y;int id;Point() {}Point(ll _x,ll _y):x(_x),y(_y) {}Point operator - (const Point& t)const{return Point(x-t.x,y-t.y);}ll operator * (const Point& t)const{return x*t.y-y*t.x;}
};
vector<Point> Graham(vector<Point> p)
{p.insert(p.begin(),Point(0,0));sort(p.begin(),p.end(),[](const Point& lhs,const Point& rhs){return lhs.x==rhs.x ? lhs.y<rhs.y : lhs.x<rhs.x;});for(size_t i=1; i<p.size(); i++)p[i].y=max(p[i].y,p[i-1].y);p.emplace_back(1000000001,p.back().y);vector<Point> res;for(auto& t : p){while(res.size()>1 && (t-res.back())*(t-res[res.size()-2])<=0)res.pop_back();res.push_back(t);}res.erase(res.begin());return res;
}
int main()
{int n;scanf("%d",&n);vector<Point> p(n);for(int i=0; i<n; i++)scanf("%lld%lld",&p[i].x,&p[i].y);p=Graham(p);n=p.size();int q;scanf("%d",&q);while(q--){Point que;scanf("%lld%lld",&que.x,&que.y);if(que*p[0]<0){printf("-1\n");continue;}int l=0,r=n-2;//l<=r+1while(l<r)//>0 =0 <0 或>0 <0渐变{int m=(l+r+1)/2;if(que*p[m]>0)l=m;else r=m-1;}db k1=1.0L*(p[l+1].y-p[l].y)/(p[l+1].x-p[l].x);db b1=p[l].y-k1*p[l].x;db k2=1.0L*que.y/que.x;db x=b1/(k2-k1),y=k2*x;printf("%.18Lf\n",que.y/y);}return 0;
}

代码2(我的二分)

#include<bits/stdc++.h>
#include<iostream>
using namespace std;
typedef long long ll;
typedef long double db;
struct Point
{ll x,y;int id;Point() {}Point(ll _x,ll _y):x(_x),y(_y) {}Point operator - (const Point& t)const{return Point(x-t.x,y-t.y);}ll operator * (const Point& t)const{return x*t.y-y*t.x;}
};
vector<Point> Graham(vector<Point> p)
{p.insert(p.begin(),Point(0,0));sort(p.begin(),p.end(),[](const Point& lhs,const Point& rhs){return lhs.x==rhs.x ? lhs.y<rhs.y : lhs.x<rhs.x;});for(size_t i=1; i<p.size(); i++)p[i].y=max(p[i].y,p[i-1].y);p.emplace_back(1000000001,p.back().y);vector<Point> res;for(auto& t : p){while(res.size()>1 && (t-res.back())*(t-res[res.size()-2])<=0)res.pop_back();res.push_back(t);}res.erase(res.begin());return res;
}
int main()
{int n;scanf("%d",&n);vector<Point> p(n);for(int i=0; i<n; i++)scanf("%lld%lld",&p[i].x,&p[i].y);p=Graham(p);n=p.size();int q;scanf("%d",&q);while(q--){Point que;scanf("%lld%lld",&que.x,&que.y);if(que*p[0]<0){printf("-1\n");continue;}int l=0,r=n-1;while(l<=r){int m=(l+r)/2;if(que*p[m]>0)l=m+1;else r=m-1;}l--;if(l<0)l=0;if(l==n-1)l--;//if(l==n-1)l--;db k1=1.0L*(p[l+1].y-p[l].y)/(p[l+1].x-p[l].x);//k1=0 b1=5 k2=8/6 x=5/(8/6)=30/8 y=30/6=5 db b1=p[l].y-k1*p[l].x;db k2=1.0L*que.y/que.x;db x=b1/(k2-k1),y=k2*x;printf("%.18Lf\n",que.y/y);}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/850879.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++ Easyx案例实战:Cookie Maker工作室1.0V

前言 //制作属于自己的工作室&#xff01; 注&#xff1a;运行效果以及下载见Cookie Maker 工作室成立程序。 关于Cookie Maker工作室成立的信息&#xff0c;I am very happy&#xff08;唔……改不过来了&#xff09;。 OKOK&#xff0c;第一次用图形库写程序&#xff08;图形…

在开源处理器架构RISC-V中发现可远程利用的中危漏洞

在RISC-V SonicBOOM处理器设计中发现中度危险的漏洞 最近&#xff0c;西北工业大学的网络空间安全学院胡伟教授团队在RISC-V SonicBOOM处理器设计中发现了一个中度危险的漏洞。这个团队的研究人员发现了一个可远程利用的漏洞&#xff0c;该漏洞存在于开源处理器架构RISC-V中。…

单灯双控开关原理

什么是单灯双控&#xff1f;顾名思义&#xff0c;指的是一个灯具可以通过两个不同的开关或控制器进行控制。 例如客厅的主灯可能会设置成单灯双控&#xff0c;一个开关位于门口&#xff0c;另一个位于房间内的另一侧&#xff0c;这样无论你是从门口进入还是从房间内出来&#x…

java web:springboot mysql开发的一套家政预约上门服务系统源码:家政上门服务系统的运行流程

java web&#xff1a;springboot mysql开发的一套家政预约上门服务系统源码&#xff1a;家政上门服务系统的运行流程 家政上门服务系统的优势 服务质量更稳定&#xff1a;由专业的家政人员提供服务&#xff0c;经过严格的培训和筛选。 价格更透明&#xff1a;采用套餐式收费&…

Word多级标题编号不连续、一级标题用大写数字二级以下用阿拉伯数字

Word多级标题编号不连续 &#xff1a; 一级标题用大写数字二级以下用阿拉伯数字&#xff1a;

墨雨云间王星越雨中情深

墨雨云间&#xff1a;王星越的雨中情深&#xff0c;吻上萧蘅&#xff0c;宿命之恋在烟雨朦胧的《墨雨云间》中&#xff0c;王星越饰演的角色&#xff0c;以其深邃的眼神和细腻的演技&#xff0c;将一段宿命之恋演绎得淋漓尽致。当镜头聚焦于他与阿狸在雨中的那一幕&#xff0c;…

(南京观海微电子)——温度对TFT影响及改善方式

温度如何损坏 LCD&#xff1f; 这个工作温度范围会影响设备内的电子部分&#xff0c;超出范围会导致 LCD 技术在高温下过热或在寒冷时变慢。 至于液晶层&#xff0c;如果放在高温下&#xff0c;它会变质&#xff0c;导致它和显示器本身出现缺陷。 LCD 温度限制&#xff1a; 什…

unity3d:GameFramework+xLua+Protobuf+lua-protobuf,与服务器交互收发协议

概述 1.cs收发协议&#xff0c;通过protobuf序列化 2.lua收发协议&#xff0c;通过lua-protobuf序列化 一条协议字节流组成 C#协议基类 CSPacketBase&#xff0c;SCPacketBaseC#用协议基类 proto生成的CS类&#xff0c;基于这两个基类。分别为CSPacketBase是客户端发送至服…

《python程序语言设计》2018版第5章第48题以0,0为圆心 绘制10个左右的同心圆

在0&#xff0c;0点处绘制10个圆。 其实这个题先要记住python不会0&#xff0c;0为原点进行绘画。 它是按半径来画&#xff0c;所以我们要先把turtle这个小画笔送到它应该去的起点。&#xff08;我经常有这样的错觉&#xff0c;每次都是这样想办法把自己拉回来&#xff09; 我…

AI视频教程下载:如何用ChatGPT来求职找工作?

这是一个关于使用ChatGPT找工作的课程&#xff0c;作者分享了自己的求职经验和技巧&#xff0c;介绍了如何使用人工智能来改进个人资料和简历&#xff0c;以及如何研究公司和面试。通过细节处理职业目标、分享个人兴趣和技能、寻求导师和专业发展机会&#xff0c;以及在行业内建…

各地业主们开始换着花样保房价了

不止杭州&#xff0c;还在广州、南京、成都...更多城市蔓延开来 各位有没有想过&#xff0c;为什么会有“保房价” 我想很多人最先听说这个词还是来自杭州业主 的确&#xff0c;作为曾经受房价影响最大的一个城市&#xff0c;杭州业主们可以说是最深谙房价上涨逻辑的那泼人了…

【计算机网络基础知识】

首先举一个生活化的例子&#xff0c;当你和朋友打电话时&#xff0c;你可能会使用三次握手和四次挥手的过程进行类比&#xff1a; 三次握手&#xff08;Three-Way Handshake&#xff09;&#xff1a; 你打电话给朋友&#xff1a;你首先拨打你朋友的电话号码并等待他接听。这就…

为什么在 TypeScript 中应优先使用类型而非接口

类型和接口是每个 TypeScript 程序中常用的强大功能。然而&#xff0c;由于类型和接口在功能上非常相似&#xff0c;这就引出了一个问题&#xff1a;哪一个更好&#xff1f; 今天&#xff0c;我们将评估类型和接口&#xff0c;并得出结论&#xff0c;为什么在大多数情况下你应该…

HikariCP连接池初识

HikariCP的简单介绍 hikari-光&#xff0c;hikariCP取义&#xff1a;像光一样轻和快的Connetion Pool。这个几乎只用java写的中间件连接池&#xff0c;极其轻量并注重性能&#xff0c;HikariCP目前已是SpringBoot默认的连接池&#xff0c;伴随着SpringBoot和微服务的普及&…

ssm汽车在线销售系统

摘 要 21世纪的今天&#xff0c;随着社会的不断发展与进步&#xff0c;人们对于信息科学化的认识&#xff0c;已由低层次向高层次发展&#xff0c;由原来的感性认识向理性认识提高&#xff0c;管理工作的重要性已逐渐被人们所认识&#xff0c;科学化的管理&#xff0c;使信息存…

稀疏高效扩散模型:推动扩散模型的部署与应用

数据驱动的世界中&#xff0c;生成模型扮演着至关重要的角色&#xff0c;尤其是在需要创建逼真样本的任务中。扩散模型&#xff08;Diffusion Models, DM&#xff09;&#xff0c;以其卓越的样本质量和广泛的模式覆盖能力&#xff0c;已经成为众多数据生成任务的首选。然而&…

nginx: [error] invalid PID number ““ in “/run/nginx.pid“

两种问题&#xff0c;我自己碰到的情况 ./nginx -s reload执行命令后报错 nginx: [error] invalid PID number ““ in “/run/nginx.pid“ 第一种情况&#xff0c;pid被注释了 /usr/local/nginx/conf/nginx.conf #user nobody; worker_processes 1;// 可能是这里被注释了…

【UE5:CesiumForUnreal】——从地球全景聚焦到某区域的动画制作

目录 1.添加Render Texture并和SceneCapture2D关联 1.1 场景准备 1.2 添加Render Texture 1.3 添加SceneCapture2D并关联 2.在Widget上显示Render Texture 2.1 创建Widget 2.2 配置Widget 2.3 添加控制按钮 2.4 添加窗口逻辑 3.制作Sequencer动画 3.1 创建Sequencer…

基于实验的电动汽车动力电池SOC

前言 本文为笔者在学习《基于MATLAB的新能源汽车仿真》过程中学习笔记&#xff0c;所涉及的表格数据和公式均为书籍里的。仿真数据是网上找的恒电流放电数据。本文仅作为笔者的入门学习记录。 一、分析动力电池SOC估算方法 SOC是指动力电池按照规定放电条件可以释放的容量占…

计算机网络 期末复习(谢希仁版本)第5章

**屏蔽作用&#xff1a;**运输层向高层用户屏蔽了下面网络核心的细节&#xff08;如网络拓扑、所采用的路由选择协议等&#xff09;&#xff0c;使应用进程看见的就是好像在两个运输层实体之间有一条端到端的逻辑通信信道。 10. 端口用一个 16 位端口号进行标志&#xff0c;允许…