hdu3015,poj1990树状数组
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3015
题意:给定n组数,每组数有值x和值h,求n组数两两的val的总和。将所有x和所有h分别离散化(不去重)变成x'和h',val(i,j)为abs(x'i-x'j)*min(hi',hj')。
如:
x, h——>x',h'
10,100——>1,1
50,500——>4,4
20,200——>3,3
20,100——>1,1
思路:只要把n*n优化成n*logn就可以过。
tip1:按照h'的值sort,并动态加点,每次加的点如果是已加点中h'最小的,那么min()中要取的值就为h'
tip2:离散化但是不去重,不需要unique
tip3:关于abs()部分的处理,两棵树状数组,一棵统计数量,一棵统计sum。abs()值为(大于x'的sum-大于x'的数量*x')+(小于x'的数量*x'-小于x'的sum)
tip4:res和sum树状数组均需要开long long
附上代码:
#include<iostream>
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
const int maxn=1e5+;
int C1[maxn],C2[maxn],n;
int lowbit(int x)
{
return x&-x;
}
void add1(int x,int c)
{
for(;x<=n;x+=lowbit(x))
C1[x]+=c;
}
void add2(int x,int c)
{
for(;x<=n;x+=lowbit(x))
C2[x]+=c;
}
int query1(int x)
{
int res=;
for(;x;x-=lowbit(x))
res+=C1[x];
return res;
};
long long query2(int x)
{
long long res=;
for(;x;x-=lowbit(x))
res+=C2[x];
return res;
}
struct node
{
int x,h;
}p[maxn];
bool cmp(node a,node b)
{
if(a.h==b.h)return a.x>b.x;
else return a.h>b.h;
} int main()
{
while(scanf("%d",&n)!=EOF)
{
memset(C1,,sizeof C1);
memset(C2,,sizeof C2);
int x[maxn]={},h[maxn]={};
for(int i=;i<n;i++)scanf("%d%d",&p[i].x,&p[i].h),x[i]=p[i].x,h[i]=p[i].h;
sort(x,x+n);
sort(h,h+n);
sort(p,p+n,cmp);
long long res=;
for(int i=;i<n;i++)
{
int tmpx=lower_bound(x,x+n,p[i].x)-x+;
int tmph=lower_bound(h,h+n,p[i].h)-h+;
//cout<<tmpx<<" "<<tmph<<endl;
res+=1ll*tmph*(-1ll*tmpx*(query1(n)-query1(tmpx))+1ll*tmpx*query1(tmpx-)+query2(n)-query2(tmpx)-query2(tmpx-));
add1(tmpx,);
add2(tmpx,tmpx);
}
printf("%lld\n",res);
}
return ;
}
poj1990,一道类似的题
#include<iostream>
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
const int maxn=2e4+;
int n,C1[maxn],C2[maxn],maxp;
struct node
{
int v,place;
}p[maxn];
bool cmp(node a,node b)
{
if(a.v==b.v)return a.place>b.place;
else return a.v>b.v;
}
int lowbit(int x)
{
return x&-x;
}
void add1(int x,int c)
{
for(;x<=maxp;x+=lowbit(x))
C1[x]+=c;
}
void add2(int x,int c)
{
for(;x<=maxp;x+=lowbit(x))
C2[x]+=c;
}
int query1(int x)
{
int res=;
for(;x;x-=lowbit(x))
res+=C1[x];
return res;
}
long long query2(int x)
{
long long res=;
for(;x;x-=lowbit(x))
res+=C2[x];
return res;
}
int main()
{
scanf("%d",&n);
for(int i=;i<n;i++)scanf("%d%d",&p[i].v,&p[i].place),maxp=max(maxp,p[i].place);
sort(p,p+n,cmp);
long long res=;
for(int i=n-;i>=;i--)
{
//cout<<p[i].v<<" "<<p[i].place<<endl;
res+=1ll*p[i].v*(query2(maxp)-query2(p[i].place)-p[i].place*(query1(maxp)-query1(p[i].place))+p[i].place*query1(p[i].place-)-query2(p[i].place-));
add1(p[i].place,);
add2(p[i].place,p[i].place);
//cout<<res<<endl;
}
printf("%lld\n",res);
return ;
}
hdu3015,poj1990树状数组的更多相关文章
- poj1990树状数组
Every year, Farmer John's N (1 <= N <= 20,000) cows attend "MooFest",a social gather ...
- hdu3015树状数组 poj1990的离散化版本
都是一类题目,推导调试比较烦,想出来还是不难的 /* 给定n个点对,按一维升序排序一次,每个点的序号为Di,按二维升序排序一次,每个点的序号为Hi 求sum{w(i,j)} w(i,j)=abs(Di ...
- POJ-1990 MooFest---两个树状数组
题目链接: https://vjudge.net/problem/POJ-1990 题目大意: 一群牛参加完牛的节日后都有了不同程度的耳聋,第i头牛听见别人的讲话,别人的音量必须大于v[i],当两头牛 ...
- poj1990两个树状数组
垃圾poj交不上去 /* 按权值从小到大排序, 两个树状数组维护权值小于等于并且在i左边的点的个数和权值 */ #include<iostream> #include<cstring ...
- POJ_1990 MooFest 【树状数组】
一.题面 POJ1990 二.分析 一个简单的树状数组运用.首先要把样例分析清楚,凑出57,理解一下.然后可以发现,如果每次取最大的v就可以肆无忌惮的直接去乘以坐标差值就可以了,写代码的时候是反着来的 ...
- BZOJ 1103: [POI2007]大都市meg [DFS序 树状数组]
1103: [POI2007]大都市meg Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2221 Solved: 1179[Submit][Sta ...
- bzoj1878--离线+树状数组
这题在线做很麻烦,所以我们选择离线. 首先预处理出数组next[i]表示i这个位置的颜色下一次出现的位置. 然后对与每种颜色第一次出现的位置x,将a[x]++. 将每个询问按左端点排序,再从左往右扫, ...
- codeforces 597C C. Subsequences(dp+树状数组)
题目链接: C. Subsequences time limit per test 1 second memory limit per test 256 megabytes input standar ...
- BZOJ 2434: [Noi2011]阿狸的打字机 [AC自动机 Fail树 树状数组 DFS序]
2434: [Noi2011]阿狸的打字机 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 2545 Solved: 1419[Submit][Sta ...
随机推荐
- 去重算法,简单粗暴&优化版
Remove Repeat 一.去重原理 1.进行排序 2.判断是否满足 '两个字符串相同' 的条件,相同则累加重复次数,并使用continue继续下一次循环 3.当条件不满足时,将该字符串和累计数加 ...
- 7月22 Linux作业-文件管理
习题内容 解答 1.答案 [root@centos7 ~]# echo '*/1 * * * * /usr/bin/cp /etc /data/`/usr/bin/date +\%Y-\%m-\%d` ...
- 多线程-等待(Wait)和通知(notify)
1.为了支撑多线程之间的协作,JDK提供了两个非常重要的线程接口:等待wait()方法和通知notify()方法. 这两个方法并不是在Thread类中的,而是输出在Object类.这意味着任何对象都可 ...
- UEFI+GPT电脑Win10下安装openSUSE Leap 42.2双系统
安装过程仅供参考,最后实现方式不完美. 1 准备工具,一个8G以上U盘,已装好win10的UEFI+GPT电脑(本机为SSD+HDD双硬盘) 2 所需软件: 2.1 ...
- 多线程编程(3)——synchronized原理以及使用
一.对象头 通常在java中一个对象主要包含三部分: 对象头 主要包含GC的状态..类型.类的模板信息(地址).synchronization状态等,在后面介绍. 实例数据:程序代码中定义的各种类型的 ...
- 《JAVA 程序员面试宝典(第四版)》之JAVA程序设计基础概念(1)类型转换
问题主题:类型转换 书页号码:37页 题目: 讨论点:答案不是D,应该是B 理由:看下面在编译器输入的结果 知识扩展:装箱与拆箱, == 与 equals 区别 之前也老是听说什么装箱.拆箱之 ...
- 关于手机微信端ios的input不能选中问题解决方案
最近在做一个微信端的商城,以前做web端的比较多,手机端做的相对来说要少点,老板说让我用俗称”靠谱的移动前端框架”—-AUI来搭建项目. 当时觉得用不用框架无所谓啦.结果后来写到一半把项目发布到手机上 ...
- 对js中局部变量、全局变量和闭包的理解
对js中局部变量.全局变量和闭包的理解 局部变量 对于局部变量,js给出的定义是这样的:在 JavaScript函数内部声明的变量(使用 var)是局部变量,所以只能在函数内部访问它.(该变量的作用域 ...
- Redis 4.0鲜为人知的功能将加速您的应用程序
来源:Redislabs 作者:Kyle Davis 翻译:Kevin (公众号:中间件小哥) Redis 4.0给Redis生态带来了一个惊人的功能:Modules(模块).Modules是Redi ...
- Rust 入门 (二)
我认为学习计算机语言,应该先用后学,这一节,我们来实现一个猜数字的小游戏. 先简单介绍一个这个游戏的内容:游戏先生成一个1到100之间的任意一个数字,然后我们输入自己猜测的数字,游戏会告诉我们输入的数 ...