test20190308
测试
- 晚上考试,是 \(SCOI\ 2016\ Day\ 2\) 的题目.
妖怪
- 由于之前在洛谷上用三分水过去了,就很 \(naive\) 地打了一个三分就跑了.获得 \(10\) 分好成绩.
- 记 \(x=atk,y=dnf,k=\frac b a\) ,推下式子,有 \(strength(a,b)=x+y+x*k+y*\frac 1 k\).
- 注意到有一个我忘了的结论和这个形式很相似:过定点 \((x,y)\) ,斜率为 \(k\) 的直线在 \(x,y\) 轴上的截距之和为 \(x+y-x*k-y*\frac 1 k\).
- 于是改一下定义,记 \(k=-\frac b a<0\) ,则 \(strength(a,b)\) 即为截距之和.那么对于一个确定的斜率 \(k\) ,使得截距之和最大的那个点一定在凸包上.
- 于是先求一个凸包,再对凸包上每个点求一次可取的最小值即得答案.
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
inline int read()
{
int out=0,fh=1;
char jp=getchar();
while ((jp>'9'||jp<'0')&&jp!='-')
jp=getchar();
if (jp=='-')
fh=-1,jp=getchar();
while (jp>='0'&&jp<='9')
out=out*10+jp-'0',jp=getchar();
return out*fh;
}
const int MAXN=1e6+10;
int n;
int atk[MAXN],dnf[MAXN];
const double eps=1e-8;
struct v2{
double x,y;
v2(double x=0,double y=0):x(x),y(y){}
v2 operator + (const v2 &rhs) const
{
return v2(x+rhs.x,y+rhs.y);
}
v2 operator - (const v2 &rhs) const
{
return v2(x-rhs.x,y-rhs.y);
}
inline double operator * (const v2 &rhs) const
{
return x*rhs.y-y*rhs.x;
}
double angle()
{
return atan2(y,x);
}
bool operator < (const v2 &rhs) const
{
return x==rhs.x?y<rhs.y:x<rhs.x;
}
v2 operator ^ (const double &lambda) const
{
return v2(x*lambda,y*lambda);
}
double slop()
{
return y/x;
}
};
double calc(double k,v2 p)
{
return p.x+p.y-k*p.x-p.y/k;
}
v2 p[MAXN],stk[MAXN],origin;
int tp=0;
int cmp(v2 a,v2 b)
{
double a1=(a-origin).angle();
double a2=(b-origin).angle();
return a1==a2?a.x<b.x:a1<a2;
}
void ConvexHull()
{
sort(p+1,p+1+n);
for(int i=n;i>=1;--i)
{
while(tp>=2 && (stk[tp]-stk[tp-1])*(p[i]-stk[tp])<=0)
--tp;
stk[++tp]=p[i];
}
}
int main()
{
// freopen("monster.in","r",stdin);
// freopen("monster.out","w",stdout);
n=read();
for(int i=1; i<=n; ++i)
{
atk[i]=read(),dnf[i]=read();
p[i]=v2(dnf[i],atk[i]);
}
ConvexHull();
double ans=2e9;
for(int i=1;i<=tp;++i)
{
double k1=(i==tp?0:(stk[i]-stk[i+1]).slop());
double k2=(i==1?-2e9:(stk[i]-stk[i-1]).slop());
double k=-sqrt(1.0*stk[i].y/stk[i].x);
if(k1>=k && k>=k2)
ans=min(ans,calc(k,stk[i]));
if(i!=tp && stk[i].y>stk[i+1].y)
break;
if(i!=tp)
ans=min(ans,calc(k1,stk[i]));
}
printf("%.4lf\n",ans);
return 0;
}
美味
- 这题之前写过虽然写得很丑,用主席树搞一搞即可,应该是相对最简单的.
围棋
- 考场上妄图用一些奇奇怪怪的 \(kmp\ +\)容斥乱搞,无果,寻病终,获得 \(10\) 分好成绩.
test20190308的更多相关文章
随机推荐
- Struts2框架学习第一章——Struts2概述
本章要点 — Web应用的发展 — Model 1和Model 2 — MVC思想 — MVC模式的优势 — 常用MVC框架及其特征 — Struts 1的基本结构及其存在的问题 — We ...
- IDEA.环境
1.下载: https://www.jetbrains.com/idea/download/#section=windows 安装的版本是:Ultimate:ideaIU-2017.3.3.exe 2 ...
- C#显示接口实现和隐式接口实现
在项目中可能会遇到显示接口实现和隐式接口实现.什么意思呢?简单来说使用接口名作为方法名的前缀,这称为“显式接口实现”:传统的实现方式,称为“隐式接口实现”.隐式接口实现如下: interface IS ...
- springmvc+rest整合redis
最近在做一个项目需要用到关系数据库mysql和缓存redis,以及非关系型数据库mongoDB.昨天下午到今天上午一直在搞springmvc整合redis,期间出现的错误一直让人抓狂,在网上搜索的结果 ...
- 搭建selenium + Python环境的总结:
安装Python+Selenium 写博客是一个不错的选择,首先,是担心自己忘掉,其次,可以供大家做一个参考: 其实,这是自己第一次搭建Python环境(之前用了一周的Idle),还是比较容易的吧: ...
- 联表更新SQL语句
联表更新语句第一次写,,,主要是在实现功能上需要向repay_detail添加一个新的字段item_id.但是以前的老数据的话这个字段的值就为null 所以就写了下面一条语句就更新了老数据...SQL ...
- 解决SecureCRT下spark-shell中scala无法删除问题
转自:http://blog.csdn.net/huanbia/article/details/51318278 问题描述 当使用SecureCRT来打开Spark-shell的时候,有时会出现如下问 ...
- 使用Easy4net编写代码生成器
在项目中经常要手动创建和数据库对应的实体类,如果数据库表比较多或者表字段比较多,那会是一个工作量非常大的事情,所以我根据自己的需求写了一个简单的代码生成工具,工具使用Easy4net框架开发. 下面是 ...
- python类常用装饰器
class Myclass(object): def __init__(self): pass #必须实例化才能调用 def sayhi(self): print 'hello' #静态方法,跟类没什 ...
- ansible modules开发(二)
四 使用其他语言发开module cd /etc/ansible cat library/touch.sh #!/bin/sh args_file=$1 [ ! -f "$args_file ...