【BZOJ1568】[JSOI2008]Blue Mary开公司(李超线段树)

题面

BZOJ

洛谷

题解

是模板题啊。

#include<iostream>
#include<cstdio>
using namespace std;
#define MAX 50050
#define lson (now<<1)
#define rson (now<<1|1)
int Q,n=50000;char ch[20];
struct Node{bool fl;double k,b;}t[MAX<<2];
void Modify(int now,int l,int r,double K,double B)
{
if(!t[now].fl){t[now].fl=true,t[now].k=K;t[now].b=B;return;}
int mid=(l+r)>>1;
double l1=l*K+B,r1=r*K+B;
double l2=l*t[now].k+t[now].b,r2=r*t[now].k+t[now].b;
if(l1<=l2&&r1<=r2)return;
if(l1>l2&&r1>r2){t[now].k=K;t[now].b=B;return;}
double x=(B-t[now].b)/(t[now].k-K);
if(l1>l2)
{
if(x>mid)Modify(rson,mid+1,r,t[now].k,t[now].b),t[now].k=K,t[now].b=B;
else Modify(lson,l,mid,K,B);
}
else
{
if(x>mid)Modify(rson,mid+1,r,K,B);
else Modify(lson,l,mid,t[now].k,t[now].b),t[now].k=K,t[now].b=B;
}
}
double Query(int now,int l,int r,int x)
{
if(l==r)return t[now].k*x+t[now].b;
int mid=(l+r)>>1;double ret=t[now].k*x+t[now].b;
if(x<=mid)ret=max(ret,Query(lson,l,mid,x));
else ret=max(ret,Query(rson,mid+1,r,x));
return ret;
}
int main()
{
scanf("%d",&Q);
while(Q--)
{
scanf("%s",ch);
if(ch[0]=='P')
{
double K,B;scanf("%lf%lf",&B,&K);
Modify(1,1,n,K,B-K);
}
else
{
int x;scanf("%d",&x);
double ans=Query(1,1,n,x);
printf("%lld\n",(long long)(ans/100));
}
}
return 0;
}

【BZOJ1568】[JSOI2008]Blue Mary开公司(李超线段树)的更多相关文章

  1. [bzoj1568][JSOI2008]Blue Mary开公司——李超线段树

    题目大意 题解 这道题需要用到一种叫做李超线段树的东西.我对于李超线段树,是这样理解的: 给节点打下的标记不进行下传,而是仅仅在需要的时候进行下传,这就是所谓永久化标记. 对于这道题,借用一张图, 这 ...

  2. 【BZOJ-1568】Blue Mary开公司 李超线段树 (标记永久化)

    1568: [JSOI2008]Blue Mary开公司 Time Limit: 15 Sec  Memory Limit: 162 MBSubmit: 557  Solved: 192[Submit ...

  3. 2019.02.11 bzoj1568: [JSOI2008]Blue Mary开公司(线段树)

    传送门 题意简述:维护整体加一条线段,求单点极值. 思路: 直接上李超线段树维护即可. 代码: #include<bits/stdc++.h> #define ri register in ...

  4. JSOI2008 Blue Mary开公司 | 李超线段树学习笔记

    题目链接:戳我 这相当于是一个李超线段树的模板qwqwq,题解就不多说了. 代码如下: #include<iostream> #include<cstdio> #include ...

  5. BZOJ.1568.[JSOI2008]Blue Mary开公司(李超线段树)

    题目链接 线段树每个节点记录\(f(mid)\)最大的直线(在\(mid\)处函数值最大的直线),称作优势线段(还是直线啊...无所谓了). 如果是在区间插入线段会影响\(O(\log n)\)个区间 ...

  6. [JSOI2008]Blue Mary开公司[李超线段树]

    题面 bzoj luogu 好久以前听lxl讲过 咕掉了.. 竟然又遇到了 安利blog #include <cmath> #include <cstring> #includ ...

  7. BZOJ-1568: Blue Mary开公司 (李超线段树)

    Description Input 第一行 :一个整数N ,表示方案和询问的总数. 接下来N行,每行开头一个单词“Query”或“Project”. 若单词为Query,则后接一个整数T,表示Blue ...

  8. bzoj千题计划219:bzoj1568: [JSOI2008]Blue Mary开公司

    http://www.lydsy.com/JudgeOnline/problem.php?id=1568 写多了就觉着水了... #include<cstdio> #include< ...

  9. BZOJ1568: [JSOI2008]Blue Mary开公司

    可以平衡树或线段树维护斜率来做. 还有一种线段树直接打标记的做法: 线段树每个节点存一条线段作为标记,打标记时如果已有标记,则把占优区间小的那个线段下放. #include<cstdio> ...

  10. BZOJ1568: [JSOI2008]Blue Mary开公司【李超树】

    Description Input 第一行 :一个整数N ,表示方案和询问的总数. 接下来N行,每行开头一个单词"Query"或"Project". 若单词为Q ...

随机推荐

  1. django 路由系统,数据库操作

    一.修改配置 数据库 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME':'dbname', 'USER': ...

  2. openstack-云计算概述

    一.云计算 1.云计算解决的问题 备机准备(低配) 故障恢复 安装系统 硬件资源浪费 电力资源浪费 2.云计算概念 (1)维基百科 云计算是一种通过因特网以服务的方式提供动态可伸缩的虚拟化的资源的计算 ...

  3. 哈尔滨工程大学ACM预热赛

    https://ac.nowcoder.com/acm/contest/554#question A #include <bits/stdc++.h> using namespace st ...

  4. SQL not exist out join

    sql中exists,not exists的用法 - 飞翔-方向 积累 沉淀 - 博客园http://www.cnblogs.com/mytechblog/articles/2105785.html ...

  5. JEECG&JWT异常捕获强化处理 | Java: Meaning of catch (final SomeException e)?

    //从header中得到token String authHeader = request.getHeader(JwtConstants.AUTHORIZATION); if (authHeader ...

  6. KafKa记录

  7. css引入的两种方法link和@import的区别和用法

    link和@import都是HTML中引入CSS的语法单词. 两者的基本语法 link语法结构 <link href="外部CSS文件的URL路径" rel="st ...

  8. 神经网络-SGD-2

    接上节: 3.梯度(gradient): def numerical_gradient(f,x): h=1e-5 grad=np.zeros_like(x) for index_x in range( ...

  9. snv的使用

    1.搭建SVN服务器 (1)直接安装 (2)创建工号,分组,分配权限(图形化界面的直接操作,非图形界面的需要改配置文件conf文件夹下) (3)创建仓库,D:\Repositories\OA:cmd命 ...

  10. Django--ORM 多表查询

    一 . 建立外键 一对一建立外键 外键名称 = models.OneToOneField(to='要连接的类名', to_field='字段') 一对多建立外键 外键名称 = models.Forei ...