思路来自题解(看着题解和标程瞎吉尔比划了半天)

/*
HDU 6059 - Kanade's trio [ 字典树 ]  |  2017 Multi-University Training Contest 3
题意:
给出数组 a[N],问满足 (i<j<k) && ((A[i] xor A[j])<(A[j] xor A[k])) 的三元组数数量
限制 N<=5e5, a[i] <= 2^30
分析:
对于某一对 ai, ak ,满足条件的 aj 为:
对于 ai 和 ak 的最高的不同位 p ,满足 aj[p] == ai[p] 也就是 aj[p] != ak[p] 首先把 ak 插入字典树(从后往前),不考虑 ai 的情况下对于某个 ak 的前缀 ak[1..p],满足条件的 ak,aj 对的数目 = (j < k && ak[p] != aj[p])
这可以预处理 1 到 k-1 第 p 位为 0 or 1 的数字的个数,然后每插一个ak,就累加 aj
然后就是对于每个 ai,枚举 p ,满足条件的ak则是前缀与ai相同,第 p 位不同的个数
ans += ak[1..p]所对应的j,k对 - 不合法的即 j<=i 的 j,k 对
*/
#include <bits/stdc++.h>
using namespace std;
#define LL long long
const int N = 5e5+5;
const int SIZE = N*31;
int sum[N][30][2];
int bin[30];
namespace Trie {
int ch[SIZE][2], tot, num[SIZE];
LL ss[SIZE];//j,k对
int init(int n) {
tot = 0;
for (int i = 0; i <= n; i++)
ch[i][0] = ch[i][1] = ss[i] = num[i] = 0;
}
void insert(int x, int i) {
int now = 0;
for (int j = 29; j >= 0; j--)
{
int t = x&bin[j]; t >>= j;
if (!ch[now][t]) ch[now][t] = ++tot;
now = ch[now][t];
ss[now] += sum[i-1][j][t^1];
num[now]++;
}
}
LL query(int x, int i) {
int now = 0;
LL ans = 0;
for (int j = 29; j >= 0; j--)
{
int t = x&bin[j]; t >>= j;
if (ch[now][t^1])
{
ans += ss[ch[now][t^1]] - (LL)sum[i][j][t]*num[ch[now][t^1]];
}
if (!ch[now][t]) break;
now = ch[now][t];
}
return ans;
}
}
int t, n, a[N];
int main()
{
bin[0] = 1;
for (int i = 1; i <= 29; i++) bin[i] = bin[i-1]<<1;
scanf("%d", &t);
while (t--)
{
scanf("%d", &n);
memset(sum[0], 0, sizeof(sum[0]));
for (int i = 1; i <= n; i++)
{
scanf("%d", &a[i]);
memcpy(sum[i], sum[i-1], sizeof(sum[i]));
for (int j = 29; j >= 0; j--)
{
int t = a[i]&bin[j]; t >>= j;
sum[i][j][t]++;
}
}
Trie::init(n*30);
LL ans = 0;
for (int i = n; i >= 1; i--)
{
ans += Trie::query(a[i], i);
Trie::insert(a[i], i);
}
printf("%lld\n", ans);
}
}

以前不怎么打字典树,比赛的时候打成血崩- -,换队友上用了两棵字典树依旧血崩- -

HDU 6059 - Kanade's trio | 2017 Multi-University Training Contest 3的更多相关文章

  1. hdu 6059 Kanade's trio(字典树)

    Kanade's trio Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 524288/524288 K (Java/Others)T ...

  2. hdu 6059 Kanade's trio

    题 OwO http://acm.hdu.edu.cn/showproblem.php?pid=6059 解 由于每个数字最多是30位,枚举数字每一位考虑, 建一棵记录前缀(位的前缀,比如10拆成10 ...

  3. HDU 6057 - Kanade's convolution | 2017 Multi-University Training Contest 3

    /* HDU 6057 - Kanade's convolution [ FWT ] | 2017 Multi-University Training Contest 3 题意: 给定两个序列 A[0 ...

  4. HDU 6058 - Kanade's sum | 2017 Multi-University Training Contest 3

    /* HDU 6058 - Kanade's sum [ 思维,链表 ] | 2017 Multi-University Training Contest 3 题意: 给出排列 a[N],求所有区间的 ...

  5. HDU 6162 - Ch’s gift | 2017 ZJUT Multi-University Training 9

    /* HDU 6162 - Ch’s gift [ LCA,线段树 ] | 2017 ZJUT Multi-University Training 9 题意: N节点的树,Q组询问 每次询问s,t两节 ...

  6. HDU 6058 Kanade's sum —— 2017 Multi-University Training 3

    Kanade's sum Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Tota ...

  7. 2017 Wuhan University Programming Contest (Online Round) Lost in WHU 矩阵快速幂 一个无向图,求从1出发到达n最多经过T条边的方法数,边可以重复经过,到达n之后不可以再离开。

    /** 题目:Lost in WHU 链接:https://oj.ejq.me/problem/26 题意:一个无向图,求从1出发到达n最多经过T条边的方法数,边可以重复经过,到达n之后不可以再离开. ...

  8. 2017 Wuhan University Programming Contest (Online Round) C. Divide by Six 分析+模拟

    /** 题目:C. Divide by Six 链接:https://oj.ejq.me/problem/24 题意:给定一个数,这个数位数达到1e5,可能存在前导0.问为了使这个数是6的倍数,且没有 ...

  9. 2017 Wuhan University Programming Contest (Online Round) B Color 树形dp求染色方法数

    /** 题目:Color 链接:https://oj.ejq.me/problem/23 题意:给定一颗树,将树上的点最多染成m种颜色,有些节点不可以染成某些颜色.相邻节点颜色不同.求染色方法数. 思 ...

随机推荐

  1. Python 中 参数* 和 **

    举个例子就知道了 class test(): def __init__(self, *a, **b): print(a) print(b) print(b.get('test')) tester = ...

  2. (十四)mybatis 和 spring 整合

    目录 整合思想 整合步骤 整合之后原始 dao 开发 整合之后 Mapper 代理开发 总结 整合思想 让 spring 管理 sqlSessionFactory ,使用 单例模式 创建该对象 : 根 ...

  3. 15.Ansible安装与配置简单版

    Ansible是一个简单高效的自动化运维管理工具,用Python开发,能大批量管理N多台机器,可以并发的在多台机器上部署应用.安装软件.执行命令.配置和编排任务. 一.Ansible工作机制 从图中可 ...

  4. 怎样在微信H5中点击直接跳转到公众号

    第一步: 打开微信公众号, 随便找一篇公众号文章, 将它发送给你的某个好友. 第二步: 使用默认浏览器打开这个分享的文章链接, 然后复制链接里面的biz字段到下面这个URL中替换 第三步: 在html ...

  5. WP8的新功能-通过一个程序来启动另一个程序

    Wp8对原来的WP7做了大量的优化...其中一个就包括Protocol Association,也就是通过uri来打开另外一个程序,这也就是说,我们可以做一个程序来启动另外一个程序了,如微信,QQ之类 ...

  6. vue2.0和animate.css的结合使用

    animate.css是一款前端动画库,相似的有velocity-animate. 上述是一个完整的结构.其中重要的几个点用箭头表示出来.首先在transition组件内部,需要定义两个基本的clas ...

  7. vue统一注册组件

    文件夹下面组件数量较多,如果每一个组件先import然后在 components,虽然灭有问题,但是会导致代码量大,而且不直观 解决办法: 将图元组件进行统一注册 新建一个pixels文件,文件里面的 ...

  8. django中app_name以及namespace理解

    在写django的时候,html中反向解析经常会用到app_name 但有时候又是namespace,具体的区别如下: 大部分情况 这两者有其一就可以了. 并且两者(可以简化理解)无区别 只要一种情况 ...

  9. rabbimq 生产消费者

    composer.json { "require": { "php-amqplib/php-amqplib": "^2.9" } } com ...

  10. Spring Data JPA 大纲归纳

    第一天: springdatajpa day1:orm思想和hibernate以及jpa的概述和jpa的基本操作 day2:springdatajpa的运行原理以及基本操作 day3:多表操作,复杂查 ...