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 ...
随机推荐
- Mybatis MapperScannerConfigurer 自动扫描 将Mapper接口生成代理注入到Spring - 大新博客 - 推酷 - 360安全浏览器 7.1
Mybatis MapperScannerConfigurer 自动扫描 将Mapper接口生成代理注入到Spring - 大新博客 时间 2014-02-11 21:08:00 博客园-所有随笔区 ...
- Ansibile之playbook初识
一.playbook简介 ansiblie的任务配置文件被称为playbook,俗称“剧本”,每一个剧本(playbook)中都包含了一系列的任务,这每个任务在ansible中又被称为“戏剧”(pla ...
- java多线程与线程并发四:线程范围内的共享数据
当多个线程操作同一个共有数据时,一个线程对共有数据的改变会影响到另一个线程.比如下面这个例子:两个线程调用同一个对象的的方法,一个线程的执行结果会影响另一个线程. package com.sky.th ...
- [LC]234题 Linked List Cycle (回文链表)(链表)
①中文题目 请判断一个链表是否为回文链表. 示例 1: 输入: 1->2输出: false示例 2: 输入: 1->2->2->1输出: true进阶:你能否用 O(n) 时间 ...
- java变量与常量
常量: 定义:程序运行过程中,不能再次该表的指 作用: 1.固定的值,代表计算过程中经常用到的值,便于计算 2.用来代表一个含义 键盘:8代表up 4代表left 6代表right 5代表down ...
- 记一次Pod中java进程内存“异常”消耗
背景 环境:openshift3.11 开发反映部署在容器中的java应用内存持续增长,只升不降,具体为: java应用部署在容器中,配置的jvm参数为-Xms1024m -Xmx1024m,容器me ...
- Nginx 代理本地文件夹(Windows环境)
安装环境: win10 nginx-1.17.2 步骤: 一.打开nginx.conf 路径:\nginx-1.17.2\conf\nginx.conf 二.编辑 配置跨域以及代理文件夹路径 三.启动 ...
- D^3ctf两道 pwn
这次 的D^3ctf 又是给吊打 难顶... 所以题都是赛后解出来的,在这感谢Peanuts师傅 unprintableV 看看保护: 看看伪代码,其实代码很少 void __cdecl menu() ...
- 从零开始在ubuntu上配置深度学习开发环境
从零开始在ubuntu上配置深度学习开发环境 昨天一不小心把原来配置好的台式机的开发环境破坏了,调了半天没有调回来,索性就重装一次ubuntu系统.这篇文章主要记录一个简单的.‘傻瓜式’教程. 一.U ...
- 新闻实时分析系统-inux环境准备与设置
1.Linux系统常规设置 1)设置ip地址 项目视频里面直接使用界面修改ip比较方便,如果Linux没有安装操作界面,需要使用命令:vi /etc/sysconfig/network-scripts ...