纪念我菜的真实的一场模拟赛

首先看到这个题目,一开始就很毒瘤。一定是没有办法直接做的。

我们考虑转化问题

假设,我们选择枚举\(x\),其中\(x\)是\(10\)的若干次方,那么我们只需要求有多少对异或完比\(x\)大的数,那么就是\(x\)对于答案的贡献了。

那么应该怎么求比多少对呢?

!!!trie!!!

对于trie的每个节点,我们维护他的子树里面的数的个数,记为\(size[x]\)

我们考虑把每一个串放进trie里面去跑,如果当前这个数的这一位是1,而10的几次方对应的也是1的话,那么当前位只能选择0,即\(root=ch[root][0]\),如果10的几次方对应的位是0的话,那么这一位选择0一定是全都满足条件的,是1的不一定,那么我们可以把0的那边记录进答案里面,然后走1的那边试一试,\(ans=ans+ch[root][0],root=ch[root][1]\)

另一种情况同理

不过需要注意的是,因为我们的贪心的放,所以必须从高位到低位来循环

int query(int now,int lim)
{
int root=1;
int ans=0;
for (register int i=62;i>=0;--i)
{
if (!root) break;
if (now&(1ll << i))
{
if (lim & (1ll << i))
root=ch[root][0];
else
ans=ans+sum[ch[root][0]],root=ch[root][1];
}
else
{
if (lim&(1ll <<i))
root=ch[root][1];
else
ans=ans+sum[ch[root][1]],root=ch[root][0];
}
}
return ans;
}

对于每一个,我们都这么算,那么最后的\(ans/2\),就是我们要的答案

因为每一对,我们会重复算两遍

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<queue>
#include<map>
#include<set>
#define mk makr_pair
#define ll long long
#define int long long
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while (!isdigit(ch)) {if (ch=='-') f=-1;ch=getchar();}
while (isdigit(ch)) {x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
return x*f;
}
const int maxn = 1e5+1e2;
int n;
int a[maxn];
int ch[7000000][3];
int tot=1;
int ans;
int sum[7000000];
void insert(int now)
{
int root=1;
for (register int i=62;i>=0;--i)
{
int x = (now & (1ll << i));
if (x!=0) x=1;
else x=0;
if (!ch[root][x]) ch[root][x]=++tot;
root=ch[root][x];
sum[root]++;
}
//cout<<tot<<endl;
}
int query(int now,int lim)
{
int root=1;
int ans=0;
for (register int i=62;i>=0;--i)
{
if (!root) break;
if (now&(1ll << i))
{
if (lim & (1ll << i))
root=ch[root][0];
else
ans=ans+sum[ch[root][0]],root=ch[root][1];
}
else
{
if (lim&(1ll <<i))
root=ch[root][1];
else
ans=ans+sum[ch[root][1]],root=ch[root][0];
}
}
return ans;
}
int qsm(int i,int j)
{
//if (j==0) return 0;
int ans=1;
while (j)
{
if (j&1) ans=ans*i;
i=i*i;
j>>=1;
}
return ans;
}
signed main()
{
n=read();
for (int i=1;i<=n;++i) a[i]=read();
for (register int i=1;i<=n;++i) insert(a[i]);
int pre=0;
for (register int i=0;i<=18;++i)
{
int cnt=0;
for (register int j=1;j<=n;++j)
{
cnt=cnt+query(a[j],qsm(10,i)-1);
//cout<<i<<" "<<cnt<<endl;
}
ans=ans+cnt;
}
cout<<ans/2;
return 0;
}

LOJ6469 Magic(trie)的更多相关文章

  1. 【python】Leetcode每日一题-前缀树(Trie)

    [python]Leetcode每日一题-前缀树(Trie) [题目描述] Trie(发音类似 "try")或者说 前缀树 是一种树形数据结构,用于高效地存储和检索字符串数据集中的 ...

  2. LA3942-Remember the Word(Trie)

    题意: 有s个不同的单词,给出一个长字符串把这个字符串分解成若干个单词的连接(可重复使用),有多少种分解方法 分析: dp[i]表示i开始的字符串能分解的方法数 dp[i]=sum(dp[i+len( ...

  3. HDU 1671 Phone List (Trie)

    pid=1671">Phone List Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K ( ...

  4. hdu 1251 统计难题 (字典树(Trie)<PS:C++提交不得爆内存>)

    统计难题Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131070/65535 K (Java/Others)Total Submis ...

  5. 字典树(Trie)的java实现

    一.定义 字典树又称单词查找树,Trie树,是一种树形结构,是一种哈希树的变种.典型应用是用于统计,排序和保存大量的字符串(但不仅限于字符串),所以经常被搜索引擎系统用于文本词频统计.它的优点是:利用 ...

  6. HDU 4825-Xor Sum(trie)

    题意: 给你一组数,开始询问给一个数  求组中与该数异或值最大的数. 分析:根据异或的特点 要想得到的异或值最大 尽可能的让两个数的每位都相反 先把给定的一组数建树,数的最后一位对应的节点保存这个数的 ...

  7. 【UER #1】跳蚤OS(Trie)

    跳蚤OS 是跳蚤国自主研发的功能强大的操作系统. 跳蚤OS的文件系统与普通的文件系统类似,是个文件夹套文件夹的结构.文件系统根目录称为“//”.我们可以用文件路径来表明文件所在的位置,比如“/flea ...

  8. UVA - 11732 "strcmp()" Anyone? (trie)

    https://vjudge.net/problem/UVA-11732 题意 给定n个字符串,问用strcmp函数比较这些字符串共用多少次比较. strcmp函数的实现 int strcmp(cha ...

  9. hihoCoder 1014 Trie树 (Trie)

    #1014 : Trie树 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描写叙述 小Hi和小Ho是一对好朋友.出生在信息化社会的他们对编程产生了莫大的兴趣,他们约定好互相帮 ...

随机推荐

  1. Go测试--子测试

    目录 简介 简单的例子 子测试命名规则 过滤筛选 子测试并发 总结 简介 简单的说,子测试提供一种在一个测试函数中执行多个测试的能力,比如原来有TestA.TestB和TestC三个测试函数,每个测试 ...

  2. 1 分钟快速使用 Docker 上手最新版 Sentry-CLI - 创建一个版本

    我们可以使用官方 sentry-cli 工具操作 Sentry API,从而来为你的项目管理一些数据.它主要用于管理 iOS.Android 的调试信息文件,以及其他平台的版本(release)和源代 ...

  3. SpringBoot2.x+mybatis plus3.x集成Activit7版本

    最近在写一个开源项目ruoyi-vue-pro,暂时负责Activiti7工作流的搭建,接这个任务一个原因,是比较好奇Activiti7版本与先前的5.6版本究竟有什么区别,因为先前在工作当中,最开始 ...

  4. 1,Spark参数调优

    Spark调优 目录 Spark调优 一.代码规范 1.1 避免创建重复RDD 1.2 尽量复用同一个RDD 1.3 多次使用的RDD要持久化 1.4 使用高性能算子 1.5 好习惯 二.参数调优 资 ...

  5. shell脚本书写

    #!/bin/bash #指定脚本默认使用的命令解释器 第1行 幻数 #!/usr/bin/python #!/bin/awk #!/bin/sed

  6. 【Python从入门到精通】(二十五)Python多进程的使用

    您好,我是码农飞哥,感谢您阅读本文,欢迎一键三连哦. 本篇重点介绍Python多进程的使用,读者朋友们可以将多进程和多线程两者做一个对比学习. 干货满满,建议收藏,需要用到时常看看. 小伙伴们如有问题 ...

  7. CSS导航菜单(二级菜单)

    index.html <div class="nav"> <ul> <li> <a href="#">Java& ...

  8. MySQL实战45讲(06--10)-笔记

    目录 06 | 全局锁和表锁 :给表加个字段怎么有这么多阻碍? 全局锁 表级锁 小结 07 | 行锁功过:怎么减少行锁对性能的影响? 死锁和死锁检测 08 | 事务到底是隔离的还是不隔离的? &quo ...

  9. HCNP Routing&Switching之IS-IS邻居建立、LSDB同步、拓扑计算和路由形成

    前文我们了解了IS-IS的报文结构和类型相关话题,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/15260670.html:今天我们来聊一聊IS-IS建立邻居. ...

  10. Linux的基础指令(二)

    目录:   一.列表显示目录内容-ls    二.设置别名-alias      三.统计目录及文件空间占用情况-du       四.创建新目录 -mkdir          五.创建空文件-to ...