SGU180(树状数组,逆序对,离散)
Inversions
memory limit per test: 4096 KB
output: standard
2 3 1 5 4
这道题需要离散,树状数组求逆序对是离散后,统计加入该元素时当前数组中
已经存在多少个比它大的数,这就是该数作为逆序对后者的贡献度,然后就可以
求解了,一般需要离散化。
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<cstring>
#include<iostream>
#define N 70007
using namespace std; int n;
long long ans;
int b[N],c[N];
struct Node
{
int zhi,id;
}a[N]; bool cmp(Node x,Node y)
{
return x.zhi<y.zhi;
}
int lowbit(int x)
{
return x&(-x);
}
void change(int x,int y)
{
for (int i=x;i<=n;i+=lowbit(i))
c[i]+=y;
}
int query(int x)
{
int res=;
for (int i=x;i>=;i-=lowbit(i))
res+=c[i];
return res;
}
int main()
{
scanf("%d",&n);
for (int i=;i<=n;i++)
{
scanf("%d",&a[i].zhi);
a[i].id=i;
}
sort(a+,a+n+,cmp);
int cnt=;
for (int i=;i<=n;i++)
{
if (a[i].zhi!=a[i-].zhi) b[a[i].id]=++cnt;
else b[a[i].id]=cnt;
}
for (int i=;i<=n;i++)
{
change(b[i],);
ans=ans+query(n)-query(b[i]);
}
printf("%lld",ans);
}
SGU180(树状数组,逆序对,离散)的更多相关文章
- [树状数组+逆序对][NOIP2013]火柴排队
		火柴排队 题目描述 涵涵有两盒火柴,每盒装有n根火柴,每根火柴都有一个高度.现在将每盒中的火柴各自排成一列,同一列火柴的高度互不相同,两列火柴之间的距离定义为:∑ (ai-bi)2,i=1,2,3,. ... 
- hdu 5497 Inversion 树状数组 逆序对,单点修改
		Inversion Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=5497 ... 
- Codevs 3286 火柴排队  2013年NOIP全国联赛提高组  树状数组,逆序对
		题目:http://codevs.cn/problem/3286/ 3286 火柴排队 2013年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : ... 
- Bzoj 2789: [Poi2012]Letters  树状数组,逆序对
		2789: [Poi2012]Letters Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 278 Solved: 185[Submit][Stat ... 
- Bzoj 3295: [Cqoi2011]动态逆序对  分块,树状数组,逆序对
		3295: [Cqoi2011]动态逆序对 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2886 Solved: 924[Submit][Stat ... 
- Bzoj 3289: Mato的文件管理  莫队,树状数组,逆序对,离散化,分块
		3289: Mato的文件管理 Time Limit: 40 Sec Memory Limit: 128 MBSubmit: 1539 Solved: 665[Submit][Status][Di ... 
- Poj 2299 - Ultra-QuickSort  离散化,树状数组,逆序对
		Ultra-QuickSort Time Limit: 7000MS Memory Limit: 65536K Total Submissions: 52306 Accepted: 19194 ... 
- hdu 2838 Cow Sorting (树状数组+逆序对)
		题目 题意:给你N个排列不规则的数,任务是把它从小到大排好,每次只能交换相邻两个数,交换一次的代价为两数之和,求最小代价 拿到这道题,我根本看不出这道题和树状数组有半毛钱关系,博客之,全说用树状数组做 ... 
- 【树状数组逆序对】USACO.2011JAN-Above the median
		[题意] 给出一串数字,问中位数大于等于X的连续子串有几个.(这里如果有偶数个数,定义为偏大的那一个而非中间取平均) [思路] 下面的数据规模也小于原题,所以要改成__int64才行.没找到测试数据, ... 
- AcWing 241.楼兰图腾  (树状数组,逆序对)
		题意:在二维坐标轴上给你一些点,求出所有由三个点构成的v和∧图案的个数. 题解:因为给出的点是按横坐标的顺序给出的,所以我们可以先遍历然后求出某个点左边比它高和低的点的个数(这个过程简直和用树状数组求 ... 
随机推荐
- 马士兵讲jsp项目--BBS项目分析笔记
			1 导言 作为一个新手JAVA程序员,我相信很多人和我一样急切的想要寻找项目来做,这里我把马士兵老师讲的JAVA WEB的第一个小项目拿过来给大家分享一下. 首先,对一个项目而言我们先要认识清楚我们要 ... 
- 前端开发【第2篇:CSS】
			鸡血 样式的属性多达几千个,但别担心,按照80-20原则,常用的也就几十个,你完全可以掌握它. Css初识 HTML的诞生 早期只有HTML的时候为了让HTML更美观一点,当时页面的开发者会把颜色写到 ... 
- 基于FPGA的Sobel边缘检测的实现
			前面我们实现了使用PC端上位机串口发送图像数据到VGA显示,通过MATLAB处理的图像数据直接是灰度图像,后面我们在此基础上修改,从而实现,基于FPGA的动态图片的Sobel边缘检测.中值滤波.Can ... 
- h5audio标签
			因为音频格式有版权,各浏览器使用不同的音频格式. 音频格式兼容性 音频格式 Chrome Firefox IE9 Opera Safari MP3 支持 不支持 支持 不支持 支持 OGG 支持 支持 ... 
- java_jstl 标签库
			jstl标签库的使用以及介绍 jstl:jsp标准标签库,是jsp的标签集合,它里面封装了jsp通用的核心功能,比如:建构化的任务,迭代,条件判断,xml 文档的操作,国际化标签,sql标签,还提供框 ... 
- < 软件工程 第一次作业 >
			自我介绍: 老师好! 我叫李智强,专业是计算机科学与技术,我自己也喜欢这个专业,然后这是我第一次用博客写自我介绍,可能会写的有点不好,还请包涵. 课程期望和目标: 第一次上课,听着老师说我们可能会做很 ... 
- RMI和socket详解
			详见: http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp58 一般来说,基于CS(client-server)软件架构的开发技 ... 
- Google的SPDY协议成为HTTP 2.0的基础
			详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt384 据TNW援引 IFTF HTTP 工作组主席 Mark Notting ... 
- zabbix 问题汇总
			1.Zabbix agent on Zabbix server is unreachable for 5 minutes 查看日志sudo tailf /var/log/zabbix/zabbix_a ... 
- 201521123065《java程序设计》第10周学习总结
			1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常与多线程相关内容. 2. 书面作业 本次PTA作业题集异常.多线程 finally 题目4-2 1.1 截图你的提交结果(出现学 ... 
