HDU 4825 Xor Sum 字典树+位运算

HDU 4825 Xor Sum 字典树+位运算

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

Xor Sum

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 132768/132768 K (Java/Others)
Total Submission(s): 291    Accepted Submission(s): 151




Problem Description
Zeus 和 Prometheus 做了一个游戏,Prometheus 给 Zeus 一个集合,集合中包括了N个正整数,随后 Prometheus 将向 Zeus 发起M次询问,每次询问中包括一个正整数 S ,之后 Zeus 须要在集合其中找出一个正整数 K ,使得 K 与 S 的异或结果最大。Prometheus 为了让 Zeus 看到人类的伟大,随即允许 Zeus 能够向人类求助。你能证明人类的智慧么?

 


Input
输入包括若干组測试数据,每组測试数据包括若干行。

输入的第一行是一个整数T(T < 10),表示共同拥有T组数据。

每组数据的第一行输入两个正整数N,M(<1=N,M<=100000),接下来一行,包括N个正整数,代表 Zeus 的获得的集合,之后M行,每行一个正整数S,代表 Prometheus 询问的正整数。全部正整数均不超过2^32。
 


Output
对于每组数据,首先须要输出单独一行”Case #?:”,当中问号处应填入当前的数据组数,组数从1開始计算。

对于每一个询问,输出一个正整数K,使得K与S异或值最大。
 


Sample Input
    
    
2 3 2 3 4 5 1 5 4 1 4 6 5 6 3

 


Sample Output
    
    
Case #1: 4 3 Case #2: 4

 


Source

建一棵字典树,每一个点都有一个左儿子0和一个右儿子1,然后每插入一个值,就将该值转换为2进制挂在字典树上,最后查询找到最大值。

//437MS 24520K
#include<stdio.h>
#include<string.h>
#define ll long long
int root,q;
ll s[35]={1};
struct Node
{
    int l,r;
    ll val;
    void clear(){l=r=-1;}//初始化
}node[32*100000];
void insert(int& root,int h,ll x)
{
    if(root==-1)
    {
        root=q++;
        node[root].clear();
    }
    if(h==-1)
    {
        node[root].val=x;
        return;
    }
    if(x&s[h])insert(node[root].r,h-1,x);//这一为是1,则沿着右子树走
    else insert(node[root].l,h-1,x);//否则沿着左子树走
}
void query(int root,int h,ll x)
{
    if(h==-1)
    {
        printf("%lld\n",node[root].val);
        return;
    }
    if(((x&s[h])&&node[root].l!=-1)||(node[root].r==-1))//由于异或是0^1=0,0^0=1所以要使结果最大,则0应找1,1应找0
        query(node[root].l,h-1,x);
    else
        query(node[root].r,h-1,x);
}
int main()
{
    int t,cas=1;
    for(int i=1;i<=32;i++)
        s[i]=s[i-1]<<1;
    scanf("%d",&t);
    while(t--)
    {
        int n,m;
        q=0;
        root=-1;
        ll a,b;
        scanf("%d%d",&n,&m);
        for(int i=1;i<=n;i++)
        {
            scanf("%lld",&a);
            insert(root,32,a);
        }
        printf("Case #%d:\n",cas++);
        for(int i=1;i<=m;i++)
        {
            scanf("%lld",&b);
            query(root,32,b);
        }
    }
    return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118474.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 本地计算机上的task scheduler服务启动后停止_task

    本地计算机上的task scheduler服务启动后停止_task1.如果对应服务依赖都正常情况下,请参考下面解决方案进入注册表(cmd–>regedit,依次找到HKEY_LOCAL_MACHINE\HKEY_LOCAL_MACHINE\SOFTWARE\MICROSOFT\RPC\INTERNET,删除INTERNET,重启服务器注:删除前请导出备份…

    2022年10月11日
    4
  • 2、Tomcat集群实战,并用Nginx实现负载均衡(win环境)

    2、Tomcat集群实战,并用Nginx实现负载均衡(win环境)

    2021年6月15日
    84
  • RT-thread finsh移植到linux平台

    RT-thread finsh移植到linux平台目录FinSH介绍传统命令行模式C语言解释器模式FinSH移植移植要点效果验证代码下载参考在一次项目中,需要进行嵌入式操作系统选型,需求就是选择一款OS,既能满足当下项目的需要,又要考虑公司未来对物联网应用的扩展能力,对比了目前市面上流行的开源操作系统,诸如FreeRTOS,RTX,UCOS,RT-Thread,contiki等,最终确定了一款Io…

    2022年5月21日
    35
  • JavaScript离别之作——HTML元素操作

    JavaScript离别之作——HTML元素操作JavaScript离别之作——HTML元素操作

    2022年7月19日
    20
  • 用户使用报告_2020年抖音用户画像报告[附下载] | 行业数据报告研读[通俗易懂]

    用户使用报告_2020年抖音用户画像报告[附下载] | 行业数据报告研读[通俗易懂]▼ 更多专业报告,请关注我们 ▼▼有趣回顾:▼【小时光面馆】专一先生和善变小姐油烟情书甲壳虫的最后一英里关注公众号,后台发送关键词“2020抖音用户画像”即可获取完整版PDF报告!报告摘要本篇报告针对的是18岁以上使用抖音行为的人群,对此进行规模大小、具体属性分析、兴趣爱好的数据整理,大部分数据都采自2020年1月。抖音用户规模数据截止至2020年1月,抖音日…

    2022年6月12日
    37
  • 虚拟ip地址是如何实现的_虚拟服务器ip地址

    虚拟ip地址是如何实现的_虚拟服务器ip地址ARP是地址分析协议,其作用简单,将ip地址转换为MAC地址,使用于数据链路层。每个主机都有一个ARP高速缓存,存储同一网络中的IP地址与MAC地址之间的对应关系,当以太网中的主机发送数据时,首先要从该缓存中查询与目标IP相对应的MAC地址,并将数据发送到该MAC地址。该系统将自动维护此缓存。ARP高速缓存可以在Linux下使用arp命令。例如,物理机器A(IP为172.25.0.1)和物理机器B…

    2022年10月12日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号