COGS 2580. [HZOI 2015]偏序 II

题目传送门

  题目大意:给n个元素,每个元素有具有4个属性a,b,c,d,求i<j并且ai<aj,bi<bj,ci<cj,di<dj的i,j对数有多少?

  a,b,c,d均为1~n的排列,即不会有i,j使得ai=aj or bi=bj or ci=cj or di=dj。

题目是离线的,cdq分治可以很好的解决这一类问题。cdq套cdq套cdq再加个bit就行了。

第一层的cdq处理a,保证a有序,

第二层在第一层的基础上处理b,保证b有序,以此类推。

第三层最后处理d,将添加的加进bit,询问的查询1~d有多少个,累加进答案ans,最后反过来删掉加进去的。(相当于清空bit)

我写的是指针形的,代码会比较短……

#include<cstdio>
#include<algorithm> using namespace std; const int N=50050;
struct data { int a,b,c,d,id; bool p; } D[4][N];
int n,px,T[N],ans; bool cmp(data A,data B)
{
if(px==1) return (A.a<B.a); else
if(px==2) return (A.b<B.b); else
if(px==3) return (A.c<B.c);
} void add(int x,int v) { for(int i=x;i<=n;i+=(i&-i)) T[i]+=v; } int sum(int x) { int Ans=0; for(int i=x;i;i-=(i&-i)) Ans+=T[i]; return Ans; } void CDQ(int now,int L,int R)
{
if(L==R) return;
int Mid=(L+R)>>1; data *S=D[now+1],*F=D[now];
int s=0;
if(now==0)
{
for(int i=L;i<=Mid;i++) S[++s]=F[i],S[s].p=0;
for(int i=Mid+1;i<=R;i++) S[++s]=F[i],S[s].p=1;
} else
{
for(int i=L;i<=Mid;i++) if(!F[i].p) S[++s]=F[i];
for(int i=Mid+1;i<=R;i++) if(F[i].p) S[++s]=F[i];
}
if(s)
{
px=now+1; sort(S+1,S+1+s,cmp);
if(now==2)
{
for(int i=1;i<=s;i++)
if(!S[i].p) add(S[i].d,1); else ans+=sum(S[i].d);
for(int i=1;i<=s;i++)
if(!S[i].p) add(S[i].d,-1);
} else CDQ(now+1,1,s);
}
CDQ(now,L,Mid); CDQ(now,Mid+1,R);
} int main()
{
freopen("partial_order_two.in","r",stdin);
freopen("partial_order_two.out","w",stdout);
scanf("%d",&n); data *F=D[0];
for(int i=1;i<=n;i++) F[i].id=i;
for(int i=1;i<=n;i++) scanf("%d",&F[i].a);
for(int i=1;i<=n;i++) scanf("%d",&F[i].b);
for(int i=1;i<=n;i++) scanf("%d",&F[i].c);
for(int i=1;i<=n;i++) scanf("%d",&F[i].d);
ans=0; CDQ(0,1,n);
printf("%d\n",ans);
return 0;
}

COGS 2580. [HZOI 2015]偏序 II的更多相关文章

  1. Bitset([HZOI 2015]偏序++)

    Bitset简介 下面介绍C++ STL 中一个非常有用的东西: Bitset 类似于二进制状压,它可以把信息转化成一个01串存储起来 定义方法: 首先要#include<bitset>或 ...

  2. cogs 2123. [HZOI 2015] Glass Beads

    2123. [HZOI 2015] Glass Beads ★★★   输入文件:MinRepresentations.in   输出文件:MinRepresentations.out   简单对比时 ...

  3. cogs 2320. [HZOI 2015]聪聪的世界题解

    2320. [HZOI 2015]聪聪的世界 时间限制:6 s   内存限制:512 MB [题目描述] 背景: 聪聪的性取向有问题. 题目描述: 聪聪遇到了一个难题: 给出一个序列a1…an,完成以 ...

  4. cogs 2355. [HZOI 2015] 有标号的DAG计数 II

    题目分析 来自2013年王迪的论文<浅谈容斥原理> 设\(f_{n,S}\)表示n个节点,入度为0的点集恰好为S的方案数. 设\(g_{n,S}\)表示n个节点,入度为0的点集至少为S的方 ...

  5. COGS 2479. [HZOI 2016]偏序 [CDQ分治套CDQ分治 四维偏序]

    传送门 给定一个有n个元素的序列,元素编号为1~n,每个元素有三个属性a,b,c,求序列中满足i<j且ai<aj且bi<bj且ci<cj的数对(i,j)的个数. 对于100%的 ...

  6. COGS 2479. [HZOI 2016] 偏序 (CDQ套CDQ)

    传送门 解题思路 四维偏序问题,模仿三维偏序,第一维排序,第二维CDQ,最后剩下二元组,发现没办法处理,就继续嵌套CDQ分治.首先把二元组的左右两边分别打上不同的标记,因为统计答案时只统计左边对右边的 ...

  7. COGS 2188. [HZOI 2015] Math 题解

      题目描述: 给定n个数X1-Xn,求下面式子的值(整数部分): n<=107,xi<=109且互不相同. 分析: 其实一开始看见这道题我也吓傻了,k这么大,再说我又是数论鶸渣,打死也不 ...

  8. [COGS 2287][HZOI 2015]疯狂的机器人

    Description 题库链接 现在在二维平面内原点上有一只机器人,他每次可以选择向右走,向左走,向下走,向上走和不走(每次如果走只能走一格).机器人不能走到横坐标是负数或者纵坐标是负数的点上. 给 ...

  9. [COGS 2258][HZOI 2015]复仇的序幕曲

    Description 你还梦不梦痛不痛,回忆这么重你怎么背得动 ----序言 当年的战火硝烟已经渐渐远去,可仇恨却在阿凯蒂王子的心中越来越深 他的叔父三年前谋权篡位,逼宫杀死了他的父王,用铁血手腕平 ...

随机推荐

  1. SourceInsight3.5 Space 替换Tab

    # SourceInsight3.5 Space 替换Tab 公司要求所有的缩进都要使用空格,而不是Tab.至于使用Tab,还是Space来进行缩进,这在网上有各种各样的讨论,毕竟使用Tab可以节省很 ...

  2. hdu2121 Ice_cream’s world II 最小树形图(难)

    这题比HDU4009要难一些.做了4009,大概知道了最小树形图的解法.拿到这题,最直接的想法是暴力.n个点试过去,每个都拿来做一次根.最后WA了,估计是超时了.(很多题都是TLE说成WA,用了G++ ...

  3. spring boot的项目结构问题

    问题:spring boot项目能够正常启动,但是在浏览器访问的时候会遇到404的错误,Whitelable Error Page 404 分析及解决方案:首先Application文件要放在项目的外 ...

  4. VS Code中html 如何查找标签(5)

    1  添加几个标签 <body> <span>第一个span标签</span> <p>这是第一个p标签</p> <span>第二 ...

  5. CentOS LiveCD、LiveDVD、BinDVD、netinstall、minimal版区别在哪里

    BinDVD版——就是普通安装版,需安装到计算机硬盘才能用,bin一般都比较大,而且包含大量的常用软件,安装时无需再在线下载(大部分情况). minimal版——这个镜像文件用于安装一个非常基本的 C ...

  6. wamp的安装配置

    WAMP是指在Windows服务器上使用Apache.MySQL和PHP的集成安装环境,可以快速安装配置Web服务器. 一.下载安装包 进入官网下载:http://www.wampserver.com ...

  7. Selenium+Python+jenkins搭建web自动化测测试框架

    python-3.6.2 chrome 59.0.3071.115 chromedriver 2.9 安装python https://www.python.org/downloads/  (Wind ...

  8. Project Euler 16 Power digit sum( 大数乘法 )

    题意: 215 = 32768,而32768的各位数字之和是 3 + 2 + 7 + 6 + 8 = 26. 21000的各位数字之和是多少? 思路:大数乘法,计算 210 × 100 可加速计算,每 ...

  9. 洛谷P1914 小书童——密码

    题目背景 某蒟蒻迷上了"小书童",有一天登陆时忘记密码了(他没绑定邮箱or手机),于是便把问题抛给了神犇你. 题目描述 蒟蒻虽然忘记密码,但他还记得密码是由一串字母组成.且密码是由 ...

  10. 《代码敲不队》第八次团队作业:Alpha冲刺 第二天

    项目 内容 这个作业属于哪个课程 任课教师博客主页链接 这个作业的要求在哪里 作业链接地址 团队名称 代码敲不队 作业学习目标 掌握软件编码实现的工程要求. 团队项目github仓库地址链接 GitH ...