题目链接

题意:

有n个人要进行乒乓球比赛,每一个人都一个能力值。每一个人出现的次序就是他们住的位置

如今要求进行一场比赛,三个人,裁判的能力值在两个选手之间,住的位置也在两个人的之间

问这样的比赛一共能够进行多少次

思路:

用树状数组做,否则TLE,先从左到右扫一遍,计算每点左边大的个数和小的个数,

再从右到左扫一遍,计算每点右边大和小的个数,然后交叉相乘取和就能够了

代码例如以下:

#include<cstdio>
#include<cstring>
#include<string>
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
const int N = 1e5+10;
int n;
int p[N], c[N], li[N], la[N], ri[N], ra[N]; inline int Lowbit(int x){ return x&(-x); } void change(int u, int x)
{
while(u < N)
{
c[u] += x;
u += Lowbit(u);
}
} int get_sum(int x)
{
int ans = 0;
for(int i = x; i > 0; i -= Lowbit(i))
{
ans += c[i];
}
return ans;
} int main()
{
int t;
scanf("%d", &t);
while(t--)
{
memset(c, 0, sizeof(c));
scanf("%d", &n);
for(int i = 1; i <= n; i++)
{
scanf("%d", &p[i]);
int cnt = get_sum(p[i]);
li[i] = cnt; // i点左边比它小的
la[i] = i - cnt - 1; //i点左边比它大的
change(p[i], 1);
}
memset(c, 0, sizeof(c));
for(int i = n; i > 0; i--)
{
int cnt = get_sum(p[i]);
ri[i] = cnt; // i点右边比它小的
ra[i] = n - i - cnt; //i点右边比它大的
change(p[i], 1);
}
ll ans = 0;
for(int i = 1; i <= n; i++)
{
ans += li[i] * ra[i] + la[i] * ri[i];
}
printf("%I64d\n", ans);
}
return 0;
}

最新文章

  1. 【腾讯Bugly干货分享】微信mars 的高性能日志模块 xlog
  2. PHP 格中方法
  3. 基于H5的移动端开发,window.location.href在IOS系统无法触发问题
  4. iOS网络编程模型
  5. VC远控(一)界面设计及套接字连接测试
  6. 网络爬虫系统Heritrix的结构分析 (个人读书报告)
  7. UVa 442 (栈) Matrix Chain Multiplication
  8. ajax post提交数据, input type=submit 返回prompt aborted by user
  9. IIS7及以上伪静态报错404
  10. 完整的 dataType=text/plain jquery ajax 登录验证
  11. PAT - 基础 - 最大公约数和最小公倍数
  12. 通过预编译头文件来提高C++ Builder的编译速度
  13. AspNetCore+Swagger 生成Model 描述
  14. leetcode — reverse-linked-list-ii
  15. 安装完Ubuntu后要做的事情
  16. 乐观锁机制解决多层嵌套异步ajax问题
  17. Jersey常用注解解释 @DET、@PUT、@POST 、@DELETE等
  18. RabbitMQ随笔
  19. awesome-workflow-engines
  20. 如何彻底卸载mysql(xp)

热门文章

  1. git error: unable to write file xxx,git fatal: unable to write new index file
  2. 安装vue,并新建一个项目
  3. jQuery-niceScroll使用中父子div都存在滚动条导致错位的问题
  4. CentOS6.x 安装升级Python2.7.x Python3.4.x
  5. matlab保存图片成eps格式不全,导致latex中图片显示不全的问题
  6. 怎么将string list 转成有特殊字符分开字符串
  7. Mysql 查看连接数,状态的相关命令
  8. wxBot微信机器人框架(转)
  9. java 连接带 kerberos 验证的 phoenix
  10. UVALive 5097 Cross the Wall