博客
关于我
左神算法班笔记——异或
阅读量:279 次
发布时间:2019-03-01

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

异或应用于数组奇数次数字问题

异或运算在计算机科学中具有独特的性质,常用于解决一些巧妙的算法问题。本文将探讨如何利用异或运算来解决数组中数字出现次数奇偶性的问题。

问题一:找出出现奇数次的数字

问题描述:在一个数组中,恰好有一个数字出现了奇数次,其余数字都出现了偶数次。要求找出这个出现奇数次的数字。

解题思路

  • 异或运算的性质:相同的数字异或偶数次结果为0,奇数次结果为数字本身。
  • 因此,将所有数组中的数字依次异或,结果即为出现奇数次的数字。

代码实现

public static void printOddTimeNum1(int[] arr) {    int eor = 0;    for (int cur : arr) {        eor ^= cur;    }    System.out.println(eor);}

问题二:找出出现奇数次的两个数字

问题描述:在一个数组中,恰好有两个数字各出现了奇数次,其余数字都出现了偶数次。要求找出这两个数字。

解题思路

  • 计算所有数字的异或结果(记为eor),由于两个数字出现奇数次,eor将等于这两个数字的异或结果。
  • 找到eor的最低设置位(LSB),将数组中的数字按照该位是否为1分为两组。
  • 分别计算每组的异或结果,分别得到两个数字。
  • 代码实现

    public static void printOddTimeNum2(int[] arr) {    int eor = 0;    for (int cur : arr) {        eor ^= cur;    }    int rightOne = eor & (~eor + 1);    int onlyOne = 0;    for (int cur : arr) {        if ((cur & rightOne) == 0) {            onlyOne ^= cur;        }    }    System.out.println("两个奇数次数字:" + onlyOne + " 和 " + (onlyOne ^ eor));}

    代码解析

    • 计算异或结果(eor:将所有数字异或,得到异或结果。
    • 确定最低设置位(rightOne:通过 ~eor + 1 操作,找到eor的最低设置位。
    • 分组异或:根据rightOne位是否为1,将数组分为两组,分别计算异或结果,得到两个数字。

    通过以上方法,我们可以高效地解决这些问题,利用异或的性质简化了计算过程。

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

    你可能感兴趣的文章
    Papyrus项目常见问题解决方案
    查看>>
    Parallel.ForEach使用示例
    查看>>
    Parallel.ForEach的基础使用
    查看>>
    parallels desktop for mac安装虚拟机 之parallelsdesktop密钥 以及 parallels desktop安装win10的办公推荐可以提高办公效率...
    查看>>
    parallelStream导致LinkedList遍历时空指针的问题
    查看>>
    Parameter ‘password‘ not found. Available parameters are [md5String, param1, username, param2]
    查看>>
    ParameterizedThreadStart task
    查看>>
    Spring security之管理session
    查看>>
    paramiko模块
    查看>>
    param[:]=param-lr*param.grad/batch_size的理解
    查看>>
    spring mvc excludePathPatterns失效 如何解决spring拦截器失效 excludePathPatterns忽略失效 拦截器失效 spring免验证拦截器不起作用
    查看>>
    Spring Cloud 之注册中心 EurekaServerAutoConfiguration源码分析
    查看>>
    Parrot OS 6.2 重磅发布!推出全新 Docker 容器启动器
    查看>>
    Parrot OS 6.3 发布!全面提升安全性,新增先进工具,带来更高性能
    查看>>
    ParseChat应用源码ios版
    查看>>
    Part 2异常和错误
    查看>>
    Pascal Script
    查看>>
    Spring Boot集成Redis实现keyspace监听 | Spring Cloud 34
    查看>>
    Spring Boot中的自定义事件详解与实战
    查看>>
    Passport 密码模式
    查看>>