【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. Liunx 简单的命令说明

    cd命令在linux中用来切换或者进入目录,路径还分为相对路径和绝对路径 cd 命令:切换当前目录至其他目录 cd /:加上斜杠表示是进入到根目录. pwd命令:查看当前路径. ()cd 进入用户主目 ...

  2. Python3练习题 018:打印星号菱形

    Python的内置方法 str.center(width [, fillchar]) 就能轻而易举打印出来:str即是数量不等的星号,width即是最大宽度(7个空格),默认填充字符fillchar就 ...

  3. react 路由4 学习

    表单控件 受控表单组件 非受控的表单组件 demo:收集表单提交的数据 路由(V4) 特点:一切皆是组件 官网:https://reacttraining.com/react-router/ npm ...

  4. Html5使用canvas作图

    以下例子是项目中实际用到的.不足之处请大家指正,设计到画线,写文字,填充,文字旋转. <!DOCTYPE html> <html> <head lang="en ...

  5. C# Note4:XML序列化和反序列化(含加密解密等)

    前言 在项目中,我们经常用到各种配置文件,比如xml文件.binary文件等等,这里主要根据实践经验介绍下xml文件的序列化和反序列化(毕竟最常用). 实践背景:我要做一个用户管理功能,用户账号信息存 ...

  6. Hbase的作用

    实时动态增加列 多版本的意思为多个用户地址,多个用户信息,多个用户号码

  7. IntelliJ IDEA -- 破解

    ① 到这个地方下载 IntelliJ IDEA 注册码:http://idea.lanyus.com/  就是这个jar包:JetbrainsCrack-2.6.10-release-enc.jar ...

  8. jquery的show()和hide()方法

    显示和隐藏元素的方法 相当于CSS中的display属性 show()方法,相当于display:block hide()方法,相当于display:none

  9. ajax查看详细返回信息

    查看详细成功返回信息: success : function(data, textStatus, jqXHR) { console.log(data); console.log(textStatus) ...

  10. vscode实现vue.js项目的过程

    https://blog.csdn.net/weixin_37567150/article/details/81291433 https://blog.csdn.net/ywl570717586/ar ...