洛谷 P3332 [ZJOI2013]K大数查询 || bzoj3110
用树套树就很麻烦,用整体二分就成了裸题。。。。
错误:
1.尝试线段树套平衡树,码农,而且n*log^3(n)慢慢卡反正我觉得卡不过去
2.线段树pushdown写错。。。加法tag对于区间和的更新应该要乘上区间长度的
- #include<cstdio>
- #include<algorithm>
- #include<cstring>
- using namespace std;
- typedef long long LL;
- struct Q
- {
- LL type,a,b,c,num;
- }q[],qt1[],qt2[];
- LL ans[],qnum;
- LL n,m;
- namespace SegT
- {
- #define mid (l+((r-l)>>1))
- #define lc (num<<1)
- #define rc (num<<1|1)
- LL dat[],addv[];
- LL L,R,x;
- void pd(LL l,LL r,LL num)
- {
- if(addv[num])
- {
- dat[lc]+=(mid-l+)*addv[num];addv[lc]+=addv[num];
- dat[rc]+=(r-mid)*addv[num];addv[rc]+=addv[num];
- addv[num]=;
- }
- }
- void _addx(LL l,LL r,LL num)
- {
- if(L<=l&&r<=R) {dat[num]+=(r-l+)*x;addv[num]+=x;return;}
- pd(l,r,num);
- if(L<=mid) _addx(l,mid,lc);
- if(mid<R) _addx(mid+,r,rc);
- dat[num]=dat[lc]+dat[rc];
- }
- LL _query(LL l,LL r,LL num)
- {
- if(L<=l&&r<=R) return dat[num];
- pd(l,r,num);LL ans=;
- if(L<=mid) ans+=_query(l,mid,lc);
- if(mid<R) ans+=_query(mid+,r,rc);
- return ans;
- }
- void addx(LL l,LL r,LL d)
- {
- L=l;R=r;x=d;_addx(,n,);
- }
- LL query(LL l,LL r)
- {
- L=l;R=r;return _query(,n,);
- }
- #undef mid
- #undef lc
- #undef rc
- }
- void solve(LL lp,LL rp,LL l,LL r)
- {
- if(lp>rp) return;
- LL i;
- if(l==r)
- {
- for(i=lp;i<=rp;i++)
- if(q[i].type==)
- ans[q[i].num]=l;
- return;
- }
- LL mid=l+((r-l)>>),tlen1=,tlen2=,t;
- for(i=lp;i<=rp;i++)
- {
- if(q[i].type==)
- {
- if(q[i].c>mid)
- {
- SegT::addx(q[i].a,q[i].b,);
- qt1[++tlen1]=q[i];
- }
- else
- qt2[++tlen2]=q[i];
- }
- else
- {
- t=SegT::query(q[i].a,q[i].b);
- if(t>=q[i].c)
- qt1[++tlen1]=q[i];
- else
- qt2[++tlen2]=q[i],qt2[tlen2].c-=t;
- }
- }
- for(i=lp;i<=rp;i++)
- if(q[i].type==&&q[i].c>mid)
- SegT::addx(q[i].a,q[i].b,-);
- memcpy(q+lp,qt1+,sizeof(Q)*tlen1);
- memcpy(q+lp+tlen1,qt2+,sizeof(Q)*tlen2);
- solve(lp,lp+tlen1-,mid+,r);
- solve(lp+tlen1,rp,l,mid);
- }
- int main()
- {
- LL i;
- scanf("%lld%lld",&n,&m);
- for(i=;i<=m;i++)
- {
- scanf("%lld%lld%lld%lld",&q[i].type,&q[i].a,&q[i].b,&q[i].c);
- if(q[i].type==) q[i].num=++qnum;
- }
- solve(,m,-,);
- for(i=;i<=qnum;i++) printf("%lld\n",ans[i]);
- return ;
- }
洛谷 P3332 [ZJOI2013]K大数查询 || bzoj3110的更多相关文章
- 洛谷 P3332 [ZJOI2013]K大数查询 解题报告
P3332 [ZJOI2013]K大数查询 题目描述 有\(N\)个位置,\(M\)个操作.操作有两种,每次操作如果是\(\tt{1\ a\ b\ c}\)的形式表示在第\(a\)个位置到第\(b\) ...
- 洛谷 P3332 [ZJOI2013]K大数查询 (整体二分理解)
链接: P3332 题意: 维护 \(n(1\leq n\leq 5\times10^4)\) 个可重整数集,编号从 \(1\) 到 \(n\).有 \(m(1\leq m\leq5\times10^ ...
- [洛谷P3332][ZJOI2013]K大数查询
题目大意:有$n$个位置,$m$个操作.操作有两种: $1\;l\;r\;x:$在区间$[l,r]$每个位置加上一个数$x$ $2\;l\;r\;k:$询问$[l,r]$中第$k$大的数是多少. 题解 ...
- 洛谷P3332 [ZJOI2013]K大数查询 权值线段树套区间线段树_标记永久化
Code: #include <cstdio> #include <algorithm> #include <string> #include <cstrin ...
- P3332 [ZJOI2013]K大数查询(线段树套线段树+标记永久化)
P3332 [ZJOI2013]K大数查询 权值线段树套区间线段树 把插入的值离散化一下开个线段树 蓝后每个节点开个线段树,维护一下每个数出现的区间和次数 为了防止MLE动态开点就好辣 重点是标记永久 ...
- P3332 [ZJOI2013]K大数查询
传送门 注意操作 $1$ 是在区间的每个位置加入一个数,不是加上一个值 相当于每个位置维护的是一个集合 显然树套树 一开始想的是区间线段树套权值线段树 发现这样询问区间第 $K$ 大时就要先二分答案再 ...
- P3332 [ZJOI2013]K大数查询 整体二分
终于入门整体二分了,勉勉强强算是搞懂了一个题目吧. 整体二分很多时候可以比较好的离线处理区间\(K\)大值的相关问题.考虑算法流程: 操作队列\(arr\),其中有询问和修改两类操作. 每次在答案的可 ...
- 【BZOJ3110】【LG3332】[ZJOI2013]K大数查询
[BZOJ3110][LG3332][ZJOI2013]K大数查询 题面 洛谷 BZOJ 题解 和普通的整体分治差不多 用线段树维护一下每个查询区间内大于每次二分的值\(mid\)的值即可 然后再按套 ...
- 【BZOJ3110】[Zjoi2013]K大数查询 树套树
[BZOJ3110][Zjoi2013]K大数查询 Description 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c,如果 ...
随机推荐
- JavaScript Prototype in Plain Language
非常好的文章: http://javascriptissexy.com/javascript-prototype-in-plain-detailed-language/ jan. 25 2013 14 ...
- CSDN-markdown基本的语法说明
文件夹 概述 简介Markdown CSDN Markdown的功能支持 标题 Setext形式 atx形式 区块引用 分隔线 强调 列表 无序列表 有序列表 注意事项 链接 自己主动链接 普通文本链 ...
- C和Fortran互相传递动态数组
C和Fortran的相互调用传递数值的方法有很多,但是F03标准的出笼,使用ISO_C_BINDING进行C和Fortran的互相调用有着更显著的优势: 1.与编译器和平台无关: 2.Fortran中 ...
- mysql字段去重方式
一直找不出某个字段去重的前提下,还能够显示其它字段的数据 以下是解决方法: SELECT *, COUNT(DISTINCT( province)) FROM area_info WHERE type ...
- TCP协议,UDP协议
帅爆太阳的男人 1,TCP协议 回环地址:127.0.0.1(所有电脑都这一个默认回环地址)每个计算机都有这么一个本机地址只能被本机识别,不会被其他机器识别(因为你用这个地址传内容他就传不出去) TC ...
- jQuery的小例子
1.在html中插入子页面 <script type="text/javascript"> $(document).ready(function() { $(" ...
- 深入研究java.lang.Object类
前言:Java的类库日益庞大.所包括的类和接口也不计其数.但当中有一些非常重要的类和接口,是Java类库中的核心部分.常见的有String.Object.Class.Collection.ClassL ...
- Android连接wifi,调用系统API【转】
本文转载自:http://blog.csdn.net/aaa1050070637/article/details/54136472 直接上代码,简单粗暴,一看就懂 import android.con ...
- 一场由过滤器Filter引发的血案
一场由过滤器Filter引发的血案 事件起因 本来应该是下图的登录界面 变成了这样 What's the fuck????? 抓狂 原因 解决方法: 在过滤器中给资源文件开个绿色通道
- 专用于ASP.Net Web应用程序的日期控件
原文引入:http://blog.csdn.net/nileel/article/details/1566051 专用于ASP.Net Web应用程序的日期控件 分类: ASP.NET/C#2007 ...