C - Division

思路:我们考虑到一点,从大往小取得顺序是不会有问题的,所以可以直接主席树,但是开不下空间,我们可以log分段求。

#include<bits/stdc++.h>
#define LL long long
#define fi first
#define se second
#define mk make_pair
#define PLL pair<LL, LL>
#define PLI pair<LL, int>
#define PII pair<int, int>
#define SZ(x) ((int)x.size())
#define ull unsigned long long
using namespace std; const int N = 1e5 + ;
const int inf = 0x3f3f3f3f;
const LL INF = 0x3f3f3f3f3f3f3f3f;
const int mod = ;
const double eps = 1e-; int n, q, all, hs[ * N], hcnt, a[N], bin[];
LL ans[ * N], sum[N], csum[N];
pair<PII, int> qus[ * N];
vector<int> vc[][N]; int root[ * N], tot; struct node {
LL sum;
int cnt, ls, rs;
} o[ * N * ]; void update(int p, int l, int r, int &x, int y) {
x = ++tot;
o[x] = o[y];
o[x].sum += p;
o[x].cnt++;
if(l == r) return;
int mid = l + r >> ;
if(p <= hs[mid]) update(p, l, mid, o[x].ls, o[y].ls);
else update(p, mid + , r, o[x].rs, o[y].rs);
} LL query(int res, int l, int r, int x, int y) {
if(o[x].cnt - o[y].cnt <= res) return o[x].sum - o[y].sum;
if(l == r) return 1ll * res * hs[l];
int mid = l + r >> , cntr = o[o[x].rs].cnt - o[o[y].rs].cnt;
if(cntr >= res) return query(res, mid + , r, o[x].rs, o[y].rs);
else return o[o[x].rs].sum - o[o[y].rs].sum + query(res-cntr, l, mid, o[x].ls, o[y].ls);
} int main() {
for(int i = bin[] = ; i <= ; i++) bin[i] = bin[i - ] << ;
scanf("%d%d", &n, &q);
for(int i = ; i <= n; i++) scanf("%d", &a[i]), sum[i] = sum[i - ] + a[i];
for(int i = ; i <= q; i++) {
scanf("%d%d%d", &qus[i].fi.fi, &qus[i].fi.se, &qus[i].se);
ans[i] = sum[qus[i].fi.se] - sum[qus[i].fi.fi - ];
}
for(int i = , j = ; i <= n; i++, j = ) {
while(a[i]) {
int val = a[i] - a[i] / ;
while(val < bin[j]) j--;
vc[j][i].push_back(val);
a[i] /= ;
}
}
for(int k = ; k >= ; k--) {
tot = ; hcnt = ; all = ;
for(int i = ; i <= n; i++) csum[i] = csum[i - ] + SZ(vc[k][i]);
if(!csum[n]) continue;
for(int i = ; i <= n; i++) for(auto& t : vc[k][i]) hs[++hcnt] = t;
sort(hs + , hs + + hcnt); hcnt = unique(hs + , hs + + hcnt) - hs - ;
for(int i = ; i <= n; i++) for(auto& t : vc[k][i]) update(t, , hcnt, root[all + ], root[all]), all++;
for(int i = ; i <= q; i++) {
if(!qus[i].se) continue;
int L = qus[i].fi.fi, R = qus[i].fi.se, has = csum[R] - csum[L - ];
if(has >= qus[i].se) {
ans[i] -= query(qus[i].se, , hcnt, root[csum[R]], root[csum[L - ]]);
qus[i].se = ;
} else {
ans[i] -= query(has, , hcnt, root[csum[R]], root[csum[L - ]]);
qus[i].se -= has;
}
}
}
for(int i = ; i <= q; i++) printf("%lld\n", ans[i]);
return ;
} /*
*/

2019 CCPC wannfly winter camp Day 5的更多相关文章

  1. 2019 CCPC wannfly winter camp Day 8

    E - Souls-like Game 直接线段树合并矩阵会被卡T掉,因为修改的复杂度比询问的复杂度多一个log,所以我们考虑优化修改. 修改的瓶颈在于打lazy的时候, 所以我们预处理出每个修改矩阵 ...

  2. 2020 CCPC Wannafly Winter Camp Day1 C. 染色图

    2020 CCPC Wannafly Winter Camp Day1 C. 染色图 定义一张无向图 G=⟨V,E⟩ 是 k 可染色的当且仅当存在函数 f:V↦{1,2,⋯,k} 满足对于 G 中的任 ...

  3. CCPC Wannafly Winter Camp Div2 部分题解

    Day 1, Div 2, Prob. B - 吃豆豆 题目大意 wls有一个\(n\)行\(m\)列的棋盘,对于第\(i\)行第\(j\)列的格子,每过\(T[i][j]\)秒会在上面出现一个糖果, ...

  4. 2020 CCPC Wannafly Winter Camp Day1 Div.1&amp F

    #include<bits/stdc++.h> #define forn(i, n) for (int i = 0; i < int(n); i++) #define fore(i, ...

  5. 2020 CCPC Wannafly Winter Camp Day1 - I. K小数查询(分块)

    题目链接:K小数查询 题意:给你一个长度为$n$序列$A$,有$m$个操作,操作分为两种: 输入$x,y,c$,表示对$i\in[x,y] $,令$A_{i}=min(A_{i},c)$ 输入$x,y ...

  6. 2020 CCPC Wannafly Winter Camp Day2-K-破忒头的匿名信

    题目传送门 sol:先通过AC自动机构建字典,用$dp[i]$表示长串前$i$位的最小代价,若有一个单词$s$是长串的前$i$项的后缀,那么可以用$dp[i - len(s)] + val(s)$转移 ...

  7. 2020 CCPC Wannafly Winter Camp Day1-F-乘法

    题目传送门 sol:二分答案$K$,算大于$K$的乘积有多少个.关键在于怎么算这个个数,官方题解上给出的复杂度是$O(nlogn)$,那么计算个数的复杂度是$O(n)$的.感觉写着有点困难,自己写了一 ...

  8. 2019 wannafly winter camp day 3

    2019 wannafly winter camp day 3 J 操作S等价于将S串取反,然后依次遍历取反后的串,每次加入新字符a,当前的串是T,那么这次操作之后的串就是TaT.这是第一次转化. 涉 ...

  9. 2019 wannafly winter camp

    2019 wannafly winter camp Name Rank Solved A B C D E F G H I J K day1 9 5/11 O O O O O day2 5 3/11 O ...

随机推荐

  1. STEM 是个怎样高大上的东西?

    近几年来,STEM 教育概念传入中国,并且越来越多地成为家长及教育机构关注的焦点. STEM教育概念同时成为了各大小教育机构及公司宣传造势的赚钱工具,可家长.学生.老师们真的理解究竟何为 STEM/S ...

  2. 解题:HNOI 2014 世界树

    题面 首先建虚树 DFS求虚树上每个点所属的点和到它所属点的距离,然后在=考虑虚树所有的边(对应原树一条链).如果两个端点所属节点不同就倍增出分界点统计答案,否则不用管(之后会统计到的):注意根节点特 ...

  3. NO.2: 尽量以const,enum,inline 替换 #define

    1.首先#define 定义不重视作用域(scope),虽然可以#undef控制,但是不美观,还存在多次替换的问题,以及没有任何封装性. 2.const XXX_XX,保证其常量性以及可控的作用域,如 ...

  4. linux 系统文件类型、系统安装时间、系统启动时间、系统运行时间、设置及显示时间、系统时间和硬件时间

    系统文件类型: 1) $mout 2) df -l:仅列出本地文件系统:-h (--human-readable):-T:文件系统类型 $df -lhf 3) file -s (--special-f ...

  5. sqlserver收缩日志的几种方式

    sqlserver收缩日志的几种方式   [sql] --参考    压缩日志及数据库文件大小      /*--特别注意       请按步骤进行,未进行前面的步骤,请不要做后面的步骤    否则可 ...

  6. 20155201 2016-2017-2 《Java程序设计》第五周学习总结

    20155201 2016-2017-2 <Java程序设计>第五周学习总结 教材学习内容总结 第八章 异常处理 程序设计本身的错误,建议使用Exception或其子类实例来表现,称错误处 ...

  7. 用MFC(C++)实现拼音搜索

    2015年4月1日更新: 我在github开源了Objective-C版的拼音搜索项目,感兴趣的可以去看看: OC版拼音搜索 最近项目需要实现按照拼音搜索资源.在网上找了一下,这方面的东西太少了. J ...

  8. 如何使用optipng压缩png图片

    OptiPNG – Google推荐的png图片无损压缩工具下载及使用教程 2014年08月24日 实用软件 暂无评论 optipng png图片无损压缩工具介绍: optipng png图片无损压缩 ...

  9. PyTorch学习系列(九)——参数_初始化

    from:http://blog.csdn.net/VictoriaW/article/details/72872036 之前我学习了神经网络中权值初始化的方法 那么如何在pytorch里实现呢. P ...

  10. RabbitMQ集群使用Haproxy负载均衡

    (1).下载 http://www.haproxy.org/#down (2).解压 tar -zxvf haproxy-1.5.18.tar.gz (3).安装 1).编译 make TARGET= ...