19-11-13-Night-∠
连夜补博客
ZJ:
看见T1就自闭了。(高考数学)(但是好像不是)
三个暴力就结束了。
35
|
Miemeng | 20
00:00:41
|
10
00:00:41
|
10
00:00:41
|
40
00:00:41
|
TJ:
T1
又是凸包凹包口包吕包旧包巨包
那么我们先看下函数$f(x)=a x^2 + b x$
这函数好啊。
都过原点。
然鹅并没有用,
好象还是有点用的。
我们考虑化柿子(话说这玩意有什么柿子可说)
$a_1 x^2+b_1x < a_2 x^2 + b_2 x$
那么就可以分情况讨论了,
$x>0 , a_1 x + b_1 < a_2 x + b_2 $
$x<0 , a_1 x + b_1 > a_2 x + b_2 $
$x=0$直接输出$0$
我们发现可以用一条直线来‘代表’这个二次函数。
于是求$x>0$时的下凸包,$x>0$时的上凸包。
细节较多,尤其是……
还是见代码吧。
#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdio>
#define N 555555
#define LL long long
#define LF long double
#define ans(k) ans[(k)+44444] using namespace std; int ln,qn;
struct Lines{
LL ar,br;
LL fig(LL x){
return ar*x*x+br*x;
}
}ps[N];
template <typename T>
class Mystack{
T A[N*10];
public:
int tp;
Mystack(){tp=0;}
T& operator [](const int id){return A[id];}
bool empty(){return tp==0;}
int size(){return tp;}
void clear(){tp=0;}
void push(const T k){A[tp++]=k;}
T top(){return A[tp-1];}
T ttop(){return A[tp-2];}
void pop(){tp--;}
void pour(){
puts("Stack:");
for(int i=0;i<tp;i++)
cout<<A[i].ar<<" "<<A[i].br<<endl;
puts("---------");
}
};
Mystack <Lines> st1,st2;
LL ans[N]; bool CMP1(const Lines &a,const Lines &b){
return a.ar==b.ar?a.br<b.br:a.ar<b.ar;
}
bool CMP2(const Lines &a,const Lines &b){
return a.ar==b.ar?a.br>b.br:a.ar<b.ar;
}
LF jud(Lines a,Lines b){
return 1.0l*(b.br-a.br)/(a.ar-b.ar);
} int main(){
#ifndef LOCAL
freopen("A.in" ,"r",stdin );
freopen("A.out","w",stdout);
#endif
int a;
scanf("%d%d",&ln,&qn);
for(int i=1;i<=ln;i++){
scanf("%lld%lld",&ps[i].ar,&ps[i].br);
}
sort(ps+1,ps+ln+1,CMP1);
for(int i=1;i<=ln;i++){
while(!st1.empty() && ps[i].ar==st1.top().ar) st1.pop();
while(st1.size()>=2 && jud(st1.top(),st1.ttop()) >= jud(ps[i],st1.ttop()))
st1.pop();
st1.push(ps[i]);
}
int j=0;
for(int i=1;i<44444;i++){
while(j<st1.tp-1 && jud(st1[j],st1[j+1])<=1.*i)j++;
ans(i)=st1[j].fig(i);
}
sort(ps+1,ps+ln+1,CMP2);
for(int i=1;i<=ln;i++){
while(!st2.empty() && ps[i].ar==st2.top().ar) st2.pop();
while(st2.size()>=2 && jud(st2.top(),st2.ttop()) <= jud(ps[i],st2.ttop()))
st2.pop();
st2.push(ps[i]);
}
j=0;
for(int i=-1;i>-44444;i--){
while(j<st2.tp-1 && jud(st2[j],st2[j+1])>=1.*i)j++;
ans(i)=st2[j].fig(i);
}
for(int i=1;i<=qn;i++){
scanf("%d",&a);
printf("%lld\n",ans(a));
}
}
T2T3咕了,不如右方跳链查询。
19-11-13-Night-∠的更多相关文章
- Java每日一面(Part1:计算机网络)[19/11/13]
作者:晨钟暮鼓c个人微信公众号:程序猿的月光宝盒 1. HTTP相关[1] 1.1 HTTP简介 HTTP协议,即超文本传输协议,属于应用层的协议,他是基于请求和响应模式的无状态的 应用层协议. ...
- 数列F[19] + F[13]的值
已知数列如下:F[1]=1, F[2]=1, F[3]=5,......,F[n] =F[n-1] + 2*F[n-2],求F[19] + F[13]? #include <stdio.h> ...
- iOS app提交审核 11.13条款问题
今年开年到现在.提交app应用一直招拒,这个问题我想不明白,感觉就是一个坑.所以贴出来给大家看看. 发件人 Apple11.13 - Apps that link to external mechan ...
- Notes of Daily Scrum Meeting(11.13)
Notes of Daily Scrum Meeting(11.13) 今天邹欣老师给我们讲课大家还是很有收获的,大家课堂的参与度确实有了很大的提升,而且邹欣老师关于项目Scrum Meeting报告 ...
- 2017/11/13 Leetcode 日记
2017/11/13 Leetcode 日记 463. Island Perimeter You are given a map in form of a two-dimensional intege ...
- VR/AR软件—Mirra测试(截至2017/11/13),使AR/VR创作更加便捷
Mirra(截至2017/11/13)https://www.mirra.co/ 1.主要特点: 目前仅支持VR,不支持AR 在浏览器(仅支持chrome,firefox)上进行创作,但目前不能直接在 ...
- 11.13的C++##不想写结构,更不爱指针
//2019.11.13 卑微的Loving-Q瞎写的程序 报错请更改VS中的SDL检查// 我要去嗨了,在线卑微 1 #include<iostream> #include<std ...
- Update 19.11 for Azure Sphere
今天,微软发布了面向Azure Sphere的19.11更新,其主要亮点就是加入了对开发工具Visual Studio Code和Linux开发环境的支持.具体来讲,本次更新包含3个部分: 1. Az ...
- 「考试」noip模拟9,11,13
9.1 辣鸡 可以把答案分成 每个矩形内部连线 和 矩形之间的连线 两部分 前半部分即为\(2(w-1)(h-1)\),后半部分可以模拟求(就是讨论四种相邻的情况) 如果\(n^2\)选择暴力模拟是有 ...
- 2019-2020 ACM-ICPC Brazil Subregional Programming Contest (11/13)
\(2019-2020\ ACM-ICPC\ Brazil\ Subregional\ Programming\ Contest\) \(A.Artwork\) 并查集,把检测区域能在一起的检测器放在 ...
随机推荐
- java实现数字转中文大写
package cn.aikang.ChineseC; import java.util.Scanner; /** * @Description: TODO(这里用一句话描述这个类的作用) * @Au ...
- java Twain 直接打印/界面打印
这两天,在搞归档系统.需要用到Twain协议来驱动扫描仪. 找了两天,java的twain操作资料真的不多.而且我还是要找直接打印的功能. 后来只能静下心来看类库和源码.最后搞定他. 打印方式分为3种 ...
- Go, JS和Websocket
JS中建立Websocket连接 var ws = new WebSocket("ws://hostname/path", ["protocol1", &quo ...
- vc枚举本机端口信息
关于查看本机端口信息,可能大多数人都知道在cmd下的netstat 命令,殊不知该命令在底层也是调用相关api来实现的,相关函数有:GetTcpTableGetExtendedTcpTableGetU ...
- linux zip,tar压缩文件夹 忽略 .git 文件夾
linux zip 忽略 .git 文件夾 # zip 命令 zip -r bitvolution.zip bitvolution -x *.git* # tar命令压缩文件夹忽略 .git文件夹 t ...
- CSIC_716_20191118【常用模块的用法 Json、pickle、collections、openpyxl】
序列化模块 序列化:将python或其他语言中的数据类型,转变成字符串类型. python中的八大数据类型回顾:int float str list tuple dict set bool 反序列化: ...
- css----less预处理器
###less less是一种动态样式语言,属于css预处理器的范畴,它扩展了 CSS 语言, 增加了变量.Mixin.函数等特性,使 CSS 更易维护和扩展 LESS 既可以在 客户端 上运行 ,也 ...
- K-Anonymous Sequence
K-Anonymous Sequence 给出一个递增的长度为n的序列\(\{a_i\}\),现在你可以进行一次操作,选择若干个数,分别减少任意一个正整数,定义权值为这些正整数之和,询问操作使得新序列 ...
- 字体jquery ---
You don’t need icons! Here are 100+ unicode symbols that you can use Danny Markov December 3rd, 2014 ...
- Java 基础 - 比较方式选择(什么类型用equals()比较,什么类型用==比较)
ref: https://www.cnblogs.com/lori/p/8308671.html 在 java 中进行比较,我们需要根据比较的类型来选择合适的比较方式: 对象域,使用 equals 方 ...