LA 4329(树状数组)
算法竞赛入门经典 p197
题目大意:
一条大街上住着n个乒乓球爱好者。常常比赛切磋技术。每一个人都有一个不同的技能值a[i]。每场比赛须要3个人:两名选手,一名裁判。他们有个奇怪的约定,裁判必须住在两名选手之间,而裁判的能力值也必须在两名选手之间。问一共能组织多少种比赛。
分析:
如果a[1]到a[i-1]中小于a[i]的数有p[i]。a[i+1]到a[n]中小于a[i]的数有s[i]个;
这样当i为裁判时可以组织的比赛数目为:p[i]*(n-i-s[i]) + (i-1-p[i])*s[i];
则总比赛次数为:
ans = 0;
for i -> 1 to n (i表示选取第i个人作为裁判)
ans += p[i]*(n-i-s[i]) + (i-1-p[i])*s[i];
首先确定p[i]的值,令x[j]表示到眼下为止已经考虑过的全部a[i]中是否存在技能值为j的数;(x[j] = 0表示不存在,x[j] = 1表示存在)
memsest(x, 0, sizeof(x));(将x初始化为0);
for i -> 1 to cur (cur为考虑的当前位置,即选取的裁判位置)
x[a[i]] = 1;
则有 p[cur] = x[1]+x[2]+.....+x[a[cur]-1];
例:
如果 n = 4 a[1] = 2, a[2] = 3, a[3] = 5, a[4] = 1;
选取 cur= 3,a[cur] = 5; (第三个人做裁判)
p[3] = x[1]+x[2]+x[3]+x[4] = 0 + 1 + 1 + 0 = 2;(这里 x[1] = 0的原因是没有运行到第4个)
不断的记录求和,当然是没有问题的(时间开销非常大)
for i -> 1 to n;
x[a[i]] = 1;
p[i] = 0;
for j -> 1 to a[i]-1
p[i] += x[j]
改动单个元素并求前缀和是树状数组的标准使用方法,能够大幅度缩减时间(时间复杂度从O(nr)降到O(nlogr) );
for i-> 1 to n
add(a[i], 1); //(点改动)
p[i] = sum(a[i]-1); //(前缀和);
到这里结果基本上能够求出来了,那s[i]呢?类似的。方向从i -> 1 to n 改为 i -> n todown 1就可以;
代码例如以下:
#include <iostream>
#include <cstdio>
#include <cstring> using namespace std; const int maxn = 20000+10;
const int maxm = 100000+10;
int c[maxm], a[maxn], p[maxn], s[maxn], n; inline int lowbit(int x){
return x&-x;
} void add(int x, int d){
while(x <= maxm){ // 一定注意这里是maxm, 原因能够思考一下;
c[x] += d; x += lowbit(x);
}
} int sum(int x){
int ret = 0;
while(x > 0){
ret += c[x]; x -= lowbit(x);
}
return ret;
} int main()
{
int T;
scanf("%d", &T);
while(T--){
scanf("%d", &n);
for(int i = 1; i <= n; ++i)
scanf("%d", &a[i]);
memset(c, 0, sizeof(c));
for(int i = 1; i <= n; ++i){
add(a[i], 1);
p[i] = sum(a[i]-1);
}
memset(c, 0, sizeof(c));
for(int i = n; i > 0; --i){
add(a[i], 1);
s[i] = sum(a[i]-1);
}
long long ans = 0;
for(int i = 1; i <= n; ++i){
ans += p[i]*(n-i-s[i]) + (i-1-p[i])*s[i];
}
printf("%lld\n", ans);
}
return 0;
}
LA 4329(树状数组)的更多相关文章
- LA 4329 (树状数组) Ping pong
第一次写树状数组,感觉那个lowbit位运算用的相当厉害. 因为-x相当于把x的二进制位取反然后整体再加上1,所以最右边的一个1以及末尾的0,取反加一以后不变. 比如1000取反是0111加一得到10 ...
- LA 4329(树状数组)
题目描述: N <tex2html_verbatim_mark>(3N20000) <tex2html_verbatim_mark>ping pong players live ...
- poj Ping pong LA 4329 (树状数组统计数目)
Ping pong Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 2302 Accepted: 879 Descript ...
- 算法竞赛入门经典 LA 4329(树状数组)
题意: 一排有着不同能力值的人比赛,规定裁判的序号只能在两人之间,而且技能值也只能在两人之间 问题: <算法竞赛入门经典-训练指南>的分析: 上代码: #include<iostre ...
- UVALive 4329 树状数组第二题
大白书上的题目,比较巧妙的是其分析,为了求某个i点做裁判的时候的情况数,只要知道左边有多少比它小的记为ansc,右边有多少比它小的记为ansd,则总种数,必定为 ansc*(右边总数-ansd)+an ...
- TTTTTTTTTTTTT LA 2191 树状数组 稍修改
题意:给出n个数字,操作有修改(S)和输出区间和(M). #include <iostream> #include <cstdio> #include <cstring& ...
- LA 4329 Ping pong 树状数组
对于我这样一名脑残ACMer选手,这道题看了好久好久大概4天,终于知道怎样把它和“树状数组”联系到一块了. 树状数组是什么意思呢?用十个字归纳它:心里有数组,手中有前缀. 为什么要用树状数组?假设你要 ...
- LA 4329 ping-pong树状数组
题目链接: 刘汝佳,大白书,P197. 枚举裁判的位置,当裁判为i时,可以有多少种选法,如果已经知道在位置i之前有ci个数比ai小,那么在位置i之前就有i-1-ci个数比ai大. 在位置i之后有di个 ...
- 树状数组 LA 4329 亚洲赛北京赛区题
复习下树状数组 还是蛮有意思的一道题: http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&cat ...
随机推荐
- MySQL的安装和启动
一.MySQL各类安装方法的比较 在Linux系统下,MySQL有3种主要的安装方式,分别是:RPM安装.二进制安装.源码安装.三种安装方式的优缺点如下表所示: RPM安装 二进制安装 源码安装 ...
- 数字签名与数字证书以及https
数字签名与数字证书以及httpshttps://blog.csdn.net/lzghxjt/article/details/79604602
- 【Java设计模式】工厂模式
简单工厂模式 简单工厂模式不是23种里的一种,简而言之,就是有一个专门生产某个产品的类.比如下图中的鼠标工厂,专业生产鼠标,给参数0,生产戴尔鼠标,给参数1,生产惠普鼠标. 示例代码: //一个产品接 ...
- 这辈子写过的比较有意思的几个sql
递归 with myRecursion as( select * from recursion where id=1 union all select r.* from myRecursion m,r ...
- Angular——基本使用
基本介绍 1.AngularJS是一个框架(诸多类库的集合)以数据和逻辑做为驱动(核心). 2.AngularJS有着诸多特性,最为核心的是:模块化.双向数据绑定.语义化标签.依赖注入等. 模块化 使 ...
- Hibernate自动事务揪出的编码不规范
最近重构的项目(Java初学中),Service层一个获取通知记录报错: org.springframework.dao.InvalidDataAccessResourceUsageException ...
- Power Designer逆向操作(从mysql5.0生成数据库的物理模型)
Power Designer逆向操作(从mysql5.0生成数据库的物理模型) 环境:powderdesigner12.5:mysql5.0 步骤: 1. 为指定的数据库配置MySQL的ODBC数据 ...
- seam remote 返回的map结构
map结构的数据,js接收到的结构是elements下面的一个 [ {key:***,value:***}, {key:***,value:***} ] 这样子的集合,需要经过下面代码的转换才能重新变 ...
- SQL一对多取子表最新记录的所有字段(ROW_NUMBER()OVER()函数的应用)
ROW_NUMBER()OVER() 参数1:分组字段 PARTITION BY ..,..,.... 可选 参数2:排序字段 ORDER BY .. DESC 必须 实例: 根据Confir ...
- 观察者模式之Golang实现
观察者模式的具体概念原理,参见https://baike.baidu.com/item/%E8%A7%82%E5%AF%9F%E8%80%85%E6%A8%A1%E5%BC%8F/5881786?fr ...