博客
关于我
左神算法班笔记——异或
阅读量: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/

    你可能感兴趣的文章
    opencv保存图片路径包含中文乱码解决方案
    查看>>
    opencv图像分割2-GMM
    查看>>
    OpenCV学习(13) 细化算法(1)(转)
    查看>>
    OpenCV探索
    查看>>
    opencv笔记(1):图像缩放
    查看>>
    OpenCV(1)读写图像
    查看>>
    OpenCV:概念、历史、应用场景示例、核心模块、安装配置
    查看>>
    Openlayers Source基础及重点内容讲解
    查看>>
    openlayers 入门教程(八):Geoms 篇
    查看>>
    openlayers 入门教程(四):layers 篇
    查看>>
    Openlayers中使用Cluster实现缩放地图时图层聚合与取消聚合
    查看>>
    Openlayers中点击地图获取坐标并输出
    查看>>
    Openlayers中设置定时绘制和清理直线图层
    查看>>
    Openlayers图文版实战,vue项目从0到1做基础配置
    查看>>
    Openlayers实战:modifystart、modifyend互动示例
    查看>>
    Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
    查看>>
    Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
    查看>>
    Openlayers高级交互(17/20):通过坐标显示多边形,计算出最大幅宽
    查看>>
    Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
    查看>>
    Openlayers高级交互(8/20):选取feature,平移feature
    查看>>