【bzoj 3110】[Zjoi2013]K大数查询|树套树

2024-03-02 21:48

本文主要是介绍【bzoj 3110】[Zjoi2013]K大数查询|树套树,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

开始打算自己yy写了半天 弃疗

采用权值线段树套主席树


BZOJ没A  数据被加强 各种无果后 弃疗


UPD 3.16: 要来了数据 负数的没问题 。。。

tmd 居然真给 MAX_LONG_INT 


吓死我 改LL TLE哭

又改 卡时过 被fqk大爷无情嘲讽



#include <cstdio>
#include <iostream>
#include <algorithm>
using namespace std;
#define MAXN 50010
int n,m;
struct H
{int sum;int mark;int L,R;
}seg[MAXN*600];
int tot=0;
int root[MAXN*2*40];void Pushdown(int now,int l,int r)
{if(seg[now].mark==0||l==r) return ;int mid=(l+r)/2;if(seg[now].L==0) seg[now].L=++tot;{seg[seg[now].L].sum+=(mid-l+1)*seg[now].mark;seg[seg[now].L].mark+=seg[now].mark;}if(seg[now].R==0) seg[now].R=++tot;{seg[seg[now].R].sum+=(r-mid)*seg[now].mark;seg[seg[now].R].mark+=seg[now].mark;}seg[now].mark=0;
}void Add2(int now,int l,int r,int a,int b)
{if(a<=l&&r<=b){seg[now].mark+=1;seg[now].sum+=(r-l+1);return ;}Pushdown(now,l,r);int mid=(l+r)/2;if(a<=mid){if(seg[now].L==0) seg[now].L=++tot;Add2(seg[now].L,l,mid,a,b);}if(mid+1<=b){if(seg[now].R==0) seg[now].R=++tot;Add2(seg[now].R,mid+1,r,a,b);}seg[now].sum=seg[seg[now].L].sum + seg[seg[now].R].sum;
}void Add1(int now,int l,int r,int a,int b,int c)
{if(root[now]==0) root[now]=++tot;Add2(root[now],1,n,a,b);if(l==r) return ;int mid=(l+r)/2;if(c<=mid) Add1(now*2,l,mid,a,b,c);else Add1(now*2+1,mid+1,r,a,b,c);
}int Q2(int now,int l,int r,int a,int b)
{if(now==0) return 0;if(a<=l&&r<=b){return seg[now].sum;}Pushdown(now,l,r);int mid=(l+r)/2;int sum=0;if(a<=mid) sum+=Q2(seg[now].L,l,mid,a,b);if(mid+1<=b) sum+=Q2(seg[now].R,mid+1,r,a,b);return sum;
}int Q1(int now,int l,int r,int s,int t,int a,int b)
{if(s<=l&&r<=t){return Q2(root[now],1,n,a,b); }int mid=(l+r)/2;int sum=0;if(s<=mid) sum+=Q1(now*2,l,mid,s,t,a,b);if(mid+1<=t) sum+=Q1(now*2+1,mid+1,r,s,t,a,b);return sum;
}int Solve(int a,int b,int c)
{int L=1,R=n*2+1;while(L<R){int mid=(L+R)/2;int tmp=Q1(1,1,2*n+1,mid+1,2*n+1,a,b);if(tmp>=c) L=mid+1;else R=mid;}return L;
}int main()
{cin >>n >>m;for(int i=1;i<=m;i++){int opt,a,b,c;scanf("%d %d %d %d",&opt,&a,&b,&c);if(opt==1){Add1(1,1,2*n+1,a,b,c+n+1);if(tot>MAXN*600-10) return 1;}else{printf("%d\n",Solve(a,b,c)-n-1);if(tot>MAXN*600-10) return 1;}}return 0;
}




这篇关于【bzoj 3110】[Zjoi2013]K大数查询|树套树的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/767523

相关文章

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st

Redis KEYS查询大批量数据替代方案

《RedisKEYS查询大批量数据替代方案》在使用Redis时,KEYS命令虽然简单直接,但其全表扫描的特性在处理大规模数据时会导致性能问题,甚至可能阻塞Redis服务,本文将介绍SCAN命令、有序... 目录前言KEYS命令问题背景替代方案1.使用 SCAN 命令2. 使用有序集合(Sorted Set)

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

PostgreSQL如何查询表结构和索引信息

《PostgreSQL如何查询表结构和索引信息》文章介绍了在PostgreSQL中查询表结构和索引信息的几种方法,包括使用`d`元命令、系统数据字典查询以及使用可视化工具DBeaver... 目录前言使用\d元命令查看表字段信息和索引信息通过系统数据字典查询表结构通过系统数据字典查询索引信息查询所有的表名可

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

uva 10069 DP + 大数加法

代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <queue>#include <map>#include <cl

ural 1026. Questions and Answers 查询

1026. Questions and Answers Time limit: 2.0 second Memory limit: 64 MB Background The database of the Pentagon contains a top-secret information. We don’t know what the information is — you

Mybatis中的like查询

<if test="templateName != null and templateName != ''">AND template_name LIKE CONCAT('%',#{templateName,jdbcType=VARCHAR},'%')</if>

京东物流查询|开发者调用API接口实现

快递聚合查询的优势 1、高效整合多种快递信息。2、实时动态更新。3、自动化管理流程。 聚合国内外1500家快递公司的物流信息查询服务,使用API接口查询京东物流的便捷步骤,首先选择专业的数据平台的快递API接口:物流快递查询API接口-单号查询API - 探数数据 以下示例是参考的示例代码: import requestsurl = "http://api.tanshuapi.com/a

DAY16:什么是慢查询,导致的原因,优化方法 | undo log、redo log、binlog的用处 | MySQL有哪些锁

目录 什么是慢查询,导致的原因,优化方法 undo log、redo log、binlog的用处  MySQL有哪些锁   什么是慢查询,导致的原因,优化方法 数据库查询的执行时间超过指定的超时时间时,就被称为慢查询。 导致的原因: 查询语句比较复杂:查询涉及多个表,包含复杂的连接和子查询,可能导致执行时间较长。查询数据量大:当查询的数据量庞大时,即使查询本身并不复杂,也可能导致