[set]JZOJ 5821 手机信号

Description

 

Input

第一行由一个空格隔开的两个正整数 m, c,意义见题目描述。
接下来 m 行,每行可能有以下形式:
construct l r v 代表发生了第一种事件;
destruct l r 代表发生了第二种事件;
query x 代表发生了第三种事件。 

Output

对于每个 query 操作,请输出一行一个整数代表此时坐标 x 处的信号强度。
 

Sample Input

11 10000
query 5
construct 5 500 100
query 500
query 1000
construct 10 90 5 
query 44
destruct 44 66
query 55
construct 50 60 3
query 46
query 6000

Sample Output

0
975
0
9999
9775
9984
0 
 

Data Constraint

分析

用set维护三元组(l,r,v),然后对于新加入的区间和原区间重叠时,劈开与新区间相交或重合的部分即可

然后删除类似,查询有在区间内和区间外两种情况

这是第一次用set写题呢

复制代码
#include <iostream>
#include <cstdio>
#include <set>
#include <cstring>
using namespace std;
struct Ivs {
    int l,r,v;
    bool operator < (const Ivs a) const {
        return l<a.l||l==a.l&&r<a.r||l==a.l&&r==a.r&&v<a.v;
    }
};
set<Ivs> s;
long long c;
int m;
char order[30];

void Insert(int l,int r,int v) {
    s.insert((Ivs){l,r-(r-l)%v,v});
    set<Ivs>::iterator iter=s.lower_bound((Ivs){l,r-(r-l)%v,v}),p=iter;
    p--;
    if (iter!=s.begin()) {
        Ivs pstar=*p;
        if (pstar.r>=l) {
            s.erase(p);
            if (l-1>=pstar.l) 
            s.insert((Ivs){pstar.l,l-1-(l-1-pstar.l)%pstar.v,pstar.v});
            if (r+1<=pstar.r)
            s.insert((Ivs){r+1+((r+1-pstar.l)%pstar.v?pstar.v-(r+1-pstar.l)%pstar.v:0),pstar.r,pstar.v});
        }
    }
}

void Destroy(int l,int r) {
    s.insert((Ivs){l,r,-1});
    set<Ivs>::iterator iter=s.lower_bound((Ivs){l,r,-1}),p=iter,n=iter,rq;
    p--;n++;
    if (iter!=s.begin()) {
        Ivs pstar=*p;
        if (pstar.r>=l) {
            s.erase(p);
            if (l-1>=pstar.l) 
            s.insert((Ivs){pstar.l,l-1-(l-1-pstar.l)%pstar.v,pstar.v});
            if (r+1<=pstar.r)
            s.insert((Ivs){r+1+((r+1-pstar.l)%pstar.v?pstar.v-(r+1-pstar.l)%pstar.v:0),pstar.r,pstar.v});
        }
    }
    while (n!=s.end()) {
        Ivs nstar=*n;rq=n;n++;
        if (nstar.l<=r) {
            s.erase(rq);
            if (r+1<=nstar.r)
            s.insert((Ivs){r+1+((r+1-nstar.l)%nstar.v?nstar.v-(r+1-nstar.l)%nstar.v:0),nstar.r,nstar.v});
        }
        else break;
    }
    s.erase((Ivs){l,r,-1});
}

long long Query(int x) {
    long long mx=1e9+1;
    s.insert((Ivs){x,x,-1});
    set<Ivs>::iterator iter=s.lower_bound((Ivs){x,x,-1}),p=iter,n=iter;
    p--;n++;
    if (iter!=s.begin()) {
        Ivs pstar=*p;
        mx=min(mx,
        (long long)(x<=pstar.r?min((x-pstar.l)%pstar.v,pstar.v-(x-pstar.l)%pstar.v)
        :x-pstar.r));
    }
    if (n!=s.end()) mx=min(mx,(long long)(*n).l-x);
    s.erase((Ivs){x,x,-1});
    return max(0ll,c-mx*mx);
}

int main() {
    freopen("cellphone.in","r",stdin);
    freopen("cellphone.out","w",stdout);
    scanf("%d%lld",&m,&c);
    while (m--) {
        int l,r,x;
        scanf("%s%d",&order,&l);
        if (order[0]=='q') printf("%lld\n",Query(l));
        if (order[0]=='c') {
            scanf("%d%d",&r,&x);
            Insert(l,r,x);
        }
        if (order[0]=='d') {
            scanf("%d",&r);
            Destroy(l,r);
        }
    }
    fclose(stdin);fclose(stdout);
}
View Code
复制代码

 

posted @   Vagari  阅读(616)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 张高兴的大模型开发实战:(一)使用 Selenium 进行网页爬虫
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示