【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

相关文章

活用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有哪些锁   什么是慢查询,导致的原因,优化方法 数据库查询的执行时间超过指定的超时时间时,就被称为慢查询。 导致的原因: 查询语句比较复杂:查询涉及多个表,包含复杂的连接和子查询,可能导致执行时间较长。查询数据量大:当查询的数据量庞大时,即使查询本身并不复杂,也可能导致

oracle11.2g递归查询(树形结构查询)

转自: 一 二 简单语法介绍 一、树型表结构:节点ID 上级ID 节点名称二、公式: select 节点ID,节点名称,levelfrom 表connect by prior 节点ID=上级节点IDstart with 上级节点ID=节点值 oracle官网解说 开发人员:SQL 递归: 在 Oracle Database 11g 第 2 版中查询层次结构数据的快速

ElasticSearch的DSL查询⑤(ES数据聚合、DSL语法数据聚合、RestClient数据聚合)

目录 一、数据聚合 1.1 DSL实现聚合 1.1.1 Bucket聚合  1.1.2 带条件聚合 1.1.3 Metric聚合 1.1.4 总结 2.1 RestClient实现聚合 2.1.1 Bucket聚合 2.1.2 带条件聚合 2.2.3 Metric聚合 一、数据聚合 聚合(aggregations)可以让我们极其方便的实现对数据的统计、分析、运算。例如:

MySQL基础(7)- 多表查询

目录 一、笛卡尔积的错误与正确的多表查询 1.出现笛卡尔积错误 2.正确的多表查询:需要有连接条件 3.查询多个表中都存在的字段 4.SELECT和WHERE中使用表的别名 二、等值连接vs非等值连接、自连接vs非自连接 1.等值连接  vs  非等值连接 2.自连接  vs  非自连接 3.内连接  vs  外连接 4.UNION  和 UNION ALL的使用 5.7种J

Hbase Filter+Scan 查询效率优化

Hbase Filter+Scan 查询效率问题 众所周知,Hbase利用filter过滤器查询时候会进行全表扫描,查询效率低下,如果没有二级索引,在项目中很多情况需要利用filter,下面针对这种情况尝试了几种优化的方案,仅供参考,欢迎交流。 根据业务要求,作者需要根据时间范围搜索所需要的数据,所以作者设计的rowKey是以时间戳为起始字符串的。 正确尝试: 1.scan 设置 开始行和结