[树组BIT]训练两题重新理解ver.
树状数组重(jiao)新(wo)理(zuo)解(ren)
POJ-2352 加加加都给我加
输入是一行一行按照x从小到大给出的,所以对于每个点,要考虑的只是x比它小的点的个数。即记录各个x的情况,并且对于一个特定的x要把它前面的x求和。
噔噔噔,树状数组可以较优地实现改点、求和(而且好写)。
cin无法承受这么大的输入并t了,关同步也不行,只能用scanf
#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
const int ma = ;
int n;
int x, y;
int ans[ma], a[ma]; int lb(int k) { return k & (-k); } int q(int x)
{
int ans = ;
for (int i = x; i > ; i -= lb(i))ans += a[i];
return ans;
} void add(int x)
{
for (int i = x; i < ma; i += lb(i))a[i]++;
} int main()
{
cin >> n;
for(int i=;i<n;i++) {
scanf("%d%d",&x,&y);
x++;
ans[q(x)]++;
add(x);
}
for (int i = ; i < n; i++)cout << ans[i] << endl;
return ;
}
POJ-2352
对了,我发现不删掉system(“pause”)交上去也可以,诶嘿
++x是因为题目给的x是可以等于零的,而如果add(0)就会爆炸
先查后加,查询当前点之前符合条件的点的个数,然后使这个level的点的数量++,并把当前点加入x套餐(不是
POJ-3067 逆序数对&逆序对数&逆序数@_@
只有背板子能力的红小豆在发现线段树/树状数组和逆序对数有关系的时候整颗豆都是懵的
原理:将数与其位置对应,按照数的大小将位置sort,接着求当前位置前有几个位置数是比当前位置数小,再用i减去个数,得到比当前位置数大的位置数的个数,即逆序对数。
e.g. 数:1 4 3 2 位置:1 2 3 4 sort 数:1 2 3 4 位置数:1 4 3 2
以树状数组作为实现,即利用query求和,再用add把一系列树组+1
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int t, n, m, k;
int l[], r[],nu[];
int a[]; bool cmp(int i, int j) { if (l[i] == l[j])return r[i] < r[j]; return l[i] < l[j]; } int lb(int k) { return k & (-k); } int q(int x)
{
int ans = ;
for (int i = x; i > ; i -= lb(i))ans += a[i];
return ans;
} void add(int x)
{
for (int i = x; i < ; i+=lb(i))a[i]++;
} int main()
{
cin >> t;
int co = ;
while (t--) {
++co;
memset(a, , sizeof(a));
cin >> n >> m >> k;
for (int i = ; i <= k; i++) {
scanf("%d%d",&l[i],&r[i]);
nu[i] = i;
}
sort(nu + , nu + + k, cmp);
long long ans = ;
for (int i = ; i <= k; i++) {
ans += i - q(r[nu[i]])-;
add(r[nu[i]]);
}
cout << "Test case " << co << ": " << ans << endl; }
return ;
}
POJ-3067
对了,要纠正一件事,memset还是比单纯for要快一些的。
神仙用pair存的左右序号,毕竟它自带先按first从小到大再按second来sort
蒟蒻想起了间接排序法就这么实行了,除了括号有点多,好像没什么问题
因为又从1开始了,所以ans+=i-...-1
什么时候。
[树组BIT]训练两题重新理解ver.的更多相关文章
- 【BZOJ-1396&2865】识别子串&字符串识别 后缀自动机/后缀树组 + 线段树
1396: 识别子串 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 312 Solved: 193[Submit][Status][Discuss] ...
- poj 3321:Apple Tree(树状数组,提高题)
Apple Tree Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 18623 Accepted: 5629 Descr ...
- HDU 5877 dfs+ 线段树(或+树状树组)
1.HDU 5877 Weak Pair 2.总结:有多种做法,这里写了dfs+线段树(或+树状树组),还可用主席树或平衡树,但还不会这两个 3.思路:利用dfs遍历子节点,同时对于每个子节点au, ...
- 【BZOJ3244】【NOI2013】树的计数(神仙题)
[BZOJ3244][NOI2013]树的计数(神仙题) 题面 BZOJ 这题有点假,\(bzoj\)上如果要交的话请输出\(ans-0.001,ans,ans+0.001\) 题解 数的形态和编号没 ...
- 2016 第七届蓝桥杯 c/c++ B组省赛真题及解题报告
2016 第七届蓝桥杯 c/c++ B组省赛真题及解题报告 勘误1:第6题第4个 if最后一个条件粗心写错了,答案应为1580. 条件应为abs(a[3]-a[7])!=1,宝宝心理苦啊.!感谢zzh ...
- 【LeetCode】线段树 segment-tree(共9题)+ 树状数组 binary-indexed-tree(共5题)
第一部分---线段树:https://leetcode.com/tag/segment-tree/ [218]The Skyline Problem [307]Range Sum Query - Mu ...
- 第十届蓝桥杯JavaB组省赛真题
试题 A: 组队 本题总分:5 分 [问题描述] 作为篮球队教练,你需要从以下名单中选出 1 号位至 5 号位各一名球员, 组成球队的首发阵容. 每位球员担任 1 号位至 5 号位时的评分如下表所示. ...
- jquery: json树组数据输出到表格Dom树的处理方法
项目背景 项目中需要把表格重排显示 处理方法 思路主要是用历遍Json数组把json数据一个个append到5个表格里,还要给每个单元格绑定个单击弹出自定义对话框,表格分了单双行,第一行最后还要改ro ...
- hdu 1541/poj 2352:Stars(树状数组,经典题)
Stars Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submi ...
随机推荐
- Overture里镲片的使用
在我们使用Overture进行作曲编曲时,往往会增添很多乐器设备来使我们的乐器更丰富,今天我们来一起看看Overture里镲片怎么使用以及它在Overture的什么位置呢? 镲片,是一种乐器,通常指爵 ...
- Eclipse中Lombok的安装和注解说明
Lombok 可用来帮助开发人员消除 Java 的重复代码,尤其是对于简单的 Java 对象(POJO),比如说getter/setter/toString等方法的编写.它通过注解实现这一目的. 官网 ...
- 论文笔记:Auto-ReID: Searching for a Part-aware ConvNet for Person Re-Identification
Auto-ReID: Searching for a Part-aware ConvNet for Person Re-Identification 2019-03-26 15:27:10 Paper ...
- async/await 的使用
async : 使用 async 修饰符可将方法.lambda 表达式或匿名方法指定为异步. 如果对方法或表达式使用此修饰符,则其称为异步方法 await: await 运算符应用于异步方法中的任务, ...
- sourcetree,创建工作流报错:Fatal: Not a gitflow-enabled repo yet. Please run 'git flow init' first.-》解决办法
1.打开项目下.git/config文件,或者如下图操作: 2.打开config文件以后,删除所有 [gitflow *条目并保存文件 3.关闭并重新打开sourcetree 4.仓库->Git ...
- Go语言库之strconv包(转载自--http://blog.csdn.net/alvine008/article/details/51283189)
golang strconv.ParseInt 是将字符串转换为数字的函数 func ParseInt(s string, base int, bitSize int) (i int64, err e ...
- P3958 奶酪
传送门 思路: 模拟题.用并查集求出所有 “连通块” ,判断是否有 “连通块” 的最顶上和最下方都不小于奶酪的范围. Code: #include<iostream> #include&l ...
- P2685 [TJOI2012]桥
P2685 [TJOI2012]桥 思路: 先求出最短路: d1[u] : u 到 1 的最短路, d2[u] : u 到 n 的最短路 再求出一条从 1 到 n 的最短路链,然后从链上的每一个点出发 ...
- Asp.net core 学习笔记 Fluent Validation
之前就有在 .net 时代介绍过了. 这个 dll 也支持 .net core 而且一直有人维护. 对比 data annotation 的 validation, 我越来越觉得这个 fluent 好 ...
- ElasticSearch 6.2 Mapping参数说明及text类型字段聚合查询配置
背景: 由于本人使用的是6.0以上的版本es,在使用发现很多中文博客对于mapping参数的说明已过时.ES6.0以后有很多参数变化. 现我根据官网总结mapping最新的参数,希望能对大家有用处. ...