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

    你可能感兴趣的文章
    SpringBoot中重写addCorsMapping解决跨域以及提示list them explicitly or consider using “allowedOriginPatterns“ in
    查看>>
    PageHelper 解析及实现原理
    查看>>
    pageHelper分页工具的使用
    查看>>
    pageHelper分页技术
    查看>>
    PageHelper分页查询遇到的小问题
    查看>>
    SpringBoot中配置为开发模式,代码修改后不用重新运行
    查看>>
    springboot中pom.xml、application.yml、application.properties
    查看>>
    PageHelper:上手教程(最详细)
    查看>>
    PageOffice如何实现从零开始动态生成图文并茂的Word文档
    查看>>
    PageRank算法
    查看>>
    Paint类(画笔)
    查看>>
    paip.android 手机输入法制造大法
    查看>>
    paip.spring3 mvc servlet的配置以及使用最佳实践
    查看>>
    Palindrome Number leetcode java
    查看>>
    Palo Alto Networks Expedition 未授权SQL注入漏洞复现(CVE-2024-9465)
    查看>>
    Palo Alto Networks Expedition 远程命令执行漏洞(CVE-2024-9463)
    查看>>
    Palo Alto Networks PAN-OS身份认证绕过导致RCE漏洞复现(CVE-2024-0012)
    查看>>
    Panalog 日志审计系统 libres_syn_delete.php 前台RCE漏洞复现
    查看>>
    Springboot中@SuppressWarnings注解详细解析
    查看>>
    Panalog 日志审计系统 sprog_deletevent.php SQL 注入漏洞复现
    查看>>