博客
关于我
【ybtoj】【Trie】【例题2】最大异或对
阅读量:331 次
发布时间:2019-03-04

本文共 909 字,大约阅读时间需要 3 分钟。

【例题2】最大异或对


Link


解题思路

本来觉得很简单,然后因为脑(guan)抽(fu),搞了两个小时,是无语哒

先把每个数的二进制数求出来,再建Trie树

如果两个数的二进制数越早出现不同,异或值也就越大
那么再查询每个数最大的异或值时,就尽量往不同的分支走


Code

#include 
#include
using namespace std;int n, x, num, s[3200020][40], ans, now, root, trie[3200020][40];void convert(int x, int cnt) { //处理出二进制数 for (int i = 31; i >= 0; i--) s[cnt][i] = (x >> i) & 1;}int main() { scanf("%d", &n); for (int i = 1; i <= n; i++) { scanf("%d", &x); convert(x, i); root = 0; for (int j = 31; j >= 0; j--) { //建Trie if (!trie[root][s[i][j]]) trie[root][s[i][j]] = ++num; root = trie[root][s[i][j]]; } } for (int i = 1; i <= n; i++) { root = now = 0; for (int j = 31; j >= 0; j--) { if (trie[root][1 - s[i][j]]) { //如果有不同的分支,就尽量往不同分支走 now += (int)(1 << j); //累计答案 root = trie[root][1 - s[i][j]]; } else root = trie[root][s[i][j]]; } ans = max(ans, now); } printf("%d", ans);}

转载地址:http://ryiq.baihongyu.com/

你可能感兴趣的文章
MySQL分组函数
查看>>
MySQL分组查询
查看>>
Mysql分表后同结构不同名称表之间复制数据以及Update语句只更新日期加减不更改时间
查看>>
mySql分页Iimit优化
查看>>
MySQL分页查询
查看>>
mysql列转行函数是什么
查看>>
mysql创建函数报错_mysql在创建存储函数时报错
查看>>
mysql创建数据库和用户 并授权
查看>>
mysql创建数据库指定字符集
查看>>
MySql创建数据表
查看>>
MySQL创建新用户以及ERROR 1396 (HY000)问题解决
查看>>
MySQL创建用户与授权
查看>>
MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
查看>>
MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
查看>>
mysql初始密码错误问题
查看>>
mysql判断某一张表是否存在的sql语句以及方法
查看>>
mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
查看>>
mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
查看>>
mysql加强(3)~分组(统计)查询
查看>>
mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
查看>>