CF678F Lena and Queries

本文详细解析了 CF678F Lena and Queries 的算法思路,介绍了如何处理添加、删除整数对及求最大值x*q+y的问题。通过使用线段树和动态凸包技巧,实现了高效的查询处理。

CF678F Lena and Queries

题意

题目描述

time limit per test4 seconds

memory limit per test256 megabytes

inputstandard input

outputstandard output

Lena is a programmer. She got a task to solve at work.

There is an empty set of pairs of integers and n queries to process. Each query is one of three types:

Add a pair (a,b) to the set.

Remove a pair added in the query number i. All queries are numbered with integers from 1 to n.

For a given integer q find the maximal value x·q+y over all pairs (x,y) from the set.

Help Lena to process the queries.

输入输出格式

输入格式:

he first line of input contains integer n (1≤n≤3·105) — the number of queries.

Each of the next n lines starts with integer t (1≤t≤3) — the type of the query.

A pair of integers a and b (-109≤a,b≤109) follows in the query of the first type.

An integer i (1≤i≤n) follows in the query of the second type. It is guaranteed that i is less than the number of the query,

the query number i has the first type and the pair from the i-th query is not already removed.

An integer q (-109≤q≤109) follows in the query of the third type.

输出格式:

For the queries of the third type print on a separate line the desired maximal value of x·q+y.

If there are no pairs in the set print "EMPTY SET".

输入输出样例

输入样例#1:

7
3 1
1 2 3
3 1
1 -1 100
3 1
2 4
3 1

输出样例#1:

EMPTY SET
5
99
5

题目大意

莉娜是个程序员。她在工作中有一项任务要解决。

有一组空的整数对,n要处理的查询。每个查询都是三种类型中的一种:

1.加一对整数(a,b)。 2.删除在第i次操作所添加的整数对。所有查询都用整数编号从1到n。 3.对于给定的整数q 求最大值x*q+y 在所有整数对上(x,y)。 请你帮助莉娜处理查询。

输入 输入的第一行包含整数。n (1≤n≤3*10^5)-查询次数。

下一个n行以整数开头t (1≤t≤3)-查询的类型。

在t==1中接下来为一对整数a和b (-10^9≤a,b≤10^9)。

在t=2中接下来为整数i (1≤i≤n)保证i小于操作的数量

在t=3中接下来为整数q (-10^9≤q≤10^9)。

输出量 对于i==3输出当前最大的 x*q+y.

如果当前没有整数对,则输出"EMPTY SET".

Code

#include <bits/stdc++.h>
#define int long long
#define re register int  
using namespace std;
inline void read(int &x){
    x=0;char ch;bool f=0;       
    for(;!isdigit(ch);ch=getchar())f|=(ch=='-');
    for(;isdigit(ch);x=(x<<1)+(x<<3)+(ch^48),ch=getchar());
    x=f?-x:x;
}
const int N=300010,fail=1e9+7,inf=2e18;
struct node{
    int k,b;
    node () {   }
    node(int x,int y){k=x,b=y;}
    int f(int x){return k*x+b;}
    bool operator < (node x) const {
        return k!=x.k ? k<x.k : b<x.k;
    }
}kk;
vector<node>T[N<<1];
int n,cnt,op[N][3],q[N][3];
inline void add(int L,int R,int k,int b,int l,int r){
    re p=l+r|(l!=r),m=(l+r)>>1;
    if(L<=l&&r<=R) {T[p].push_back(node(k,b));return;} 
    if(L<=m)add(L,R,k,b,l,m);
    if(m<R) add(L,R,k,b,m+1,r); 
}
inline int check(vector<node>& x,int i,int j,int k){
    return ((x[i].b-x[j].b)*(x[k].k-x[i].k))>=(x[i].b-x[k].b)*(x[j].k-x[i].k);
}
inline void calc(vector<node>& x){
    static int S[N],t,i;vector<node> tmp; 
    sort(x.begin(),x.end());
    for(i=0,t=0;i<x.size();++i){
        while(t && x[S[t]].k==x[i].k || t>1 && check(x,S[t-1],S[t],i)) --t;
        S[++t]=i;
    }
    for(i=1;i<=t;++i) tmp.push_back(x[S[i]]);
    x=tmp;
}
inline int get(int x,int p){
    if(!T[p].size()) return -inf;
    re l=0,r=T[p].size()-1,m;
    while(l<r){
        m=(l+r)>>1;
        (T[p][m].f(x)>T[p][m+1].f(x))?r=m:l=m+1;
    }
    return T[p][l].f(x);
}
inline int ask(int x,int p,int l,int r){
    re res=-inf;
    while(l<r){
        re id=(l+r)|(l!=r),m=(l+r)>>1;
        res=max(res,get(x,id));
        (p<=m)?r=m:l=m+1;
    }
    return res=max(res,get(x,(l+r)|(l!=r)));
}
signed main(){
    read(n);
    for(re x,i=1;i<=n;++i){
        read(op[i][0]),read(op[i][1]);
        if(op[i][0]==1)read(op[i][2]);
        else if(op[i][0]==2){
            x=op[i][1];
            add(x,i,op[x][1],op[x][2],1,n);
            op[x][1]=op[i][1]=fail;
        }
        else{
            q[++cnt][1]=op[i][1];
            q[cnt][2]=i,op[i][1]=fail;
        } 
    }
    for(re i=1;i<=n;++i)
        if(op[i][1]!=fail)
            add(i,n,op[i][1],op[i][2],1,n);
    for(re i=1;i<=(n<<1);++i) if(T[i].size())calc(T[i]);
    for(re res,i=1;i<=cnt;++i){
        res=ask(q[i][1],q[i][2],1,n);
        (res==-inf)?puts("EMPTY SET"):printf("%lld\n",res);
    }
    return 0;
}

转载于:https://www.cnblogs.com/Sparks-Pion/p/9642747.html

【博士论文复现】【阻抗建模、验证扫频法】光伏并网逆变器扫频与稳定性分析(包含锁相环电流环)(Simulink仿真实现)内容概要:本文档围绕“博士论文复现”主题,重点介绍了光伏并网逆变器的阻抗建模与扫频法稳定性分析,涵盖锁相环和电流环的Simulink仿真实现。文档旨在通过完整的仿真资源和代码帮助科研人员复现相关技术细节,提升对新能源并网系统动态特性和稳定机制的理解。此外,文档还提供了大量其他科研方向的复现资源,包括微电网优化、机器学习、路径规划、信号处理、电力系统分析等,配套MATLAB/Simulink代码与模型,服务于多领域科研需求。; 适合人群:具备一定电力电子、自动控制或新能源背景的研究生、博士生及科研人员,熟悉MATLAB/Simulink环境,有志于复现高水平论文成果并开展创新研究。; 使用场景及目标:①复现光伏并网逆变器的阻抗建模与扫频分析过程,掌握其稳定性判据与仿真方法;②借鉴提供的丰富案例资源,支撑博士论文或期刊论文的仿真实验部分;③结合团队提供的算法与模型,快速搭建实验平台,提升科研效率。; 阅读建议:建议按文档目录顺序浏览,优先下载并运行配套仿真文件,结合理论学习与代码调试加深理解;重点关注锁相环与电流环的建模细节,同时可拓展学习其他复现案例以拓宽研究视野。
内容概要:本文系统解析了嵌入式通信协议栈系列项目的实践路径,围绕通信原理与工程实现,阐述在资源受限的嵌入式环境中构建稳定、可扩展通信能力的方法。文章从通信基础模型出发,强调分层设计思想,涵盖物理层到应用层的职责划分,并依次讲解通信驱动、数据收发机制、帧格式解析、状态机控制、错误处理等核心技术环节。项目实践注重底层可靠性建设,如中断响应、缓冲区管理与数据校验,同时关注上层应用对接,确保协议栈支持设备配置、状态上报等实际业务。文中还突出性能优化与资源管理的重要性,指导开发者在内存与处理效率间取得平衡,并通过系统化测试手段(如异常模拟、压力测试)验证协议栈的健壮性。; 适合人群:具备嵌入式系统基础知识,有一定C语言和硬件接口开发经验,从事或希望深入物联网、工业控制等领域1-3年工作经验的工程师。; 使用场景及目标:①掌握嵌入式环境下通信协议栈的分层架构设计与实现方法;②理解状态机、数据封装、异常处理等关键技术在真实项目中的应用;③提升在资源受限条件下优化通信性能与稳定性的工程能力; 阅读建议:建议结合实际嵌入式平台动手实践,边学边调,重点关注各层接口定义与模块解耦设计,配合调试工具深入分析通信流程与异常行为,以全面提升系统级开发素养。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值