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

/*
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. scrapy-redis数据去重与分布式框架

    数据去重 生成指纹:利用hashlib的sha1,对request的请求体.请求url.请求方法进行加密,返回一个40位长度的16进制的字符串,称为指纹 fp = hashlib.sha1() fp. ...

  2. dfs/bfs专项训练

    A.棋盘问题——poj1321 在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别.要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放 ...

  3. MACD中短线交易系统

    1.MA5.MA10金叉,且股价收盘站稳5日均线 2.MACD金叉 3.MACD红绿柱 a.MACD红柱发散,表示多头力量增强,此时买入或加仓 b.MACD红柱收缩,表示多头力量减弱,此时卖出或减仓 ...

  4. varchar、nvarchar

    Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示. NCHAR.NVARCHAR.NTEXT.这三种从名字上看比前面三种多了个 ...

  5. NetScaler Logs Collection Guide

    NetScaler Logs Collection Guide 来源  https://support.citrix.com/article/CTX227560 Article | Authentic ...

  6. 某康x电视去广告

    开启adb 信源选择进入模拟电视 然后按菜单键输入2008 找到其他选项,进去把adb root打开 删除对应广告视频(短暂方法) 可以下载tvbox,利用文件管理功能 进入/data/misc/ko ...

  7. ubuntu目录结构(转)

    /:根目录,一般根目录下只存放目录,不要存放文件,/etc./bin./dev./lib./sbin应该和根目录放置在一个分区中 /bin:/usr/bin:可执行二进制文件的目录,如常用的命令ls. ...

  8. Python算法题(三)——经典函数题

    题目一(统计字符串中指定类型字符的个数): 假设所有字符分为三类:字母,数字及其他字符.‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬ ...

  9. web储存的初级运用

    <html> <head> <meta charset="utf-8"> <title>web存储</title>< ...

  10. HTTP中GET,POST和PUT的区别

    一.HTTP中定义了以下几种请求方法: 1.GET:2.POST:3.PUT:4.DELETE;5.HEAD:6.TRACE:7.OPTIONS: 二.各个方法介绍: 1.GET方法:对这个资源的查操 ...