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

/*
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. 【转帖】PostgreSQL之 使用扩展Extension

    PostgreSQL之 使用扩展Extension https://www.cnblogs.com/lnlvinso/p/11042677.html 挺好的文章.自己之前没有系统学习过 扩展.. 目前 ...

  2. ES使用小结之索引Rollover

    Elasticsearch 使用小结之索引Rollover 索引名 一般而言,客户端将数据每天写入一个索引,比如直接写入YYYY-MM-HH格式的索引,那么我们只需要在写入的客户端里面获取时间,然后得 ...

  3. AtCoder M-SOLUTIONS 2019 Task E. Product of Arithmetic Progression

    problem link Official editorial: code: int main() { #if defined LOCAL && !defined DUIPAI ifs ...

  4. php静态调用非静态方法

    <?php /** * php静态调用非静态方法 * author: 百里 * Date: 2019/7/18 * Time: 17:28 */ function dump(...$var) { ...

  5. Netty的学习

    看了几天高并发和NIO 今晚终于要开始学习Netty http://ifeve.com/netty5-user-guide/ Netty实现通信的步骤 1.创建两个NIO线程组,一个专门用于网络事件的 ...

  6. AC自动机fail树上dfs序建线段树+动态memset清空

    题意:http://acm.hdu.edu.cn/showproblem.php?pid=4117 思路:https://blog.csdn.net/u013306830/article/detail ...

  7. 【Python基础】10_Python中的字典

    1.字典的定义 和列表的区别 列表是 有序 对象的集合 字典是 无序 对象的集合 字典用 {} 定义 键 key 是索引 值 value 是数据 键 和 值 之间用 :分割 键 必须是唯一的 值 可以 ...

  8. Memcached和Spring集成开发

    xml配置文件 <bean id="memcachedPool" class="com.danga.MemCached.SockIOPool" facto ...

  9. luogu4302字符串折叠题解--区间DP

    题目链接 https://www.luogu.org/problemnew/show/P4302 分析 很明显一道区间DP题,对于区间\([l,r]\)的字符串,如果它的字串是最优折叠的,那么它的最优 ...

  10. Spark RDD学习笔记

    一.学习Spark RDD RDD是Spark中的核心数据模型,一个RDD代表着一个被分区(partition)的只读数据集. RDD的生成只有两种途径: 一种是来自于内存集合或外部存储系统: 另一种 ...