java异或运算符_python 异或

java异或运算符_python 异或Java-异或运算异或运算法则异或的运算方法是一个二进制运算:例图:总结例题1例题2:136.只出现一次的数字(力扣)异或运算法则    1.a^b=b^a  2.a^b^c=a^(b^c)=(a^b)^c;  3.d=a^b^c        可以推出a=d^

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

异或运算法则

       1. a ^ b = b ^ a
  2. a ^ b ^ c = a ^ (b ^ c) = (a ^ b) ^ c;
  3. d = a ^ b ^ c                 可以推出 a = d ^ b ^ c.
  4. a ^ b ^ a = b.

异或的运算方法是一个二进制运算:

1^1=0

0^0=0

1^0=1

0^1=1

两者相等为0,不等为1.

例图:

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

总结

1、异或是一个数学运算符。应用于逻辑运算。
2、真异或假的结果是真,假异或真的结果也是真,真异或真的结果是假,假异或假的结果是假。就是说两个值相异结果为真。
3、n^0=n n^n=0,即任何数与0进行异或,为它本身,两个相同的数进行异或运算,会得到0。

例题1

那么参照上面的原则和公式我们来看看下面这道题来加深理解:
1-1000放在含有1001个元素的数组中,只有唯一的一个元素值重复,其它均只出现一次。每个数组元素只能访问一次,设计一个算法,将它找出来;不用辅助存储空间,能否设计一个算法实现?
上边这个也可以用异或运算进行解题:
假设:1^2^3......^n.....^1000=T
而: 1^2^3......^n^n.....^1000 = T^n
我们已经知道T^T^n = 0^n = n这样的过程。
所以,我们对于上边的解题办法就有了:
首先对1到1000,这1000个数进行异或运算,然后再把上边的1001个数进行异或运算,最后,再对这两个结果进行异或运算,就会得到唯一的那个n。

例题2:136. 只出现一次的数字(力扣)

那么综合上面的所有知识点让我们投入实战:

  1. 只出现一次的数字
    题目链接:https://leetcode-cn.com/problems/single-number/
class Solution { 
   
     public int singleNumber(int[] nums) { 
   
         int ans=0;
        for(int i=0;i<nums.length;i++){ 
   
            ans^=nums[i];   //异或运算
        }
        return ans;
    }
}


持续更新中…

文章参考学习地址:
https://leetcode-cn.com/problems/single-number/solution/hua-jie-suan-fa-136-zhi-chu-xian-yi-ci-de-shu-zi-b/

文章参考学习地址:
https://blog.csdn.net/wohaqiyi/article/details/80931693/

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

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

(0)
上一篇 2026年4月14日 下午2:22
下一篇 2026年4月14日 下午2:28


相关推荐

  • CSS3 按钮 打钩

    CSS3 按钮 打钩css 打钩 u icon radioSB width 22px height 22px border radius 100 position relative background 4288E3

    2026年3月16日
    3
  • 解决新版chrome跨域问题:cookie丢失以及samesite属性问题「建议收藏」

    解决新版chrome跨域问题:cookie丢失以及samesite属性问题「建议收藏」最近在使用前后端分离开发的时候,遇到了一个诡异的问题,无论如何设置跨域,同一个页面获取到的session始终不一致。发现问题:登录界面前后端分离,ajax提交登录时出错验证码接口和登录接口的session不一致(跨域问题)在网上搜索跨域问题,重新设置,问题依旧错因排除:ajax允许cookie(已经设置xhrFields:{withCredentials:true})springboot尝试设置了多种跨域方法(springboot解决跨域)深入分析:使用其它浏览器(fi

    2022年6月9日
    238
  • tcpdump抓包命令怎么用_linux系统抓包工具

    tcpdump抓包命令怎么用_linux系统抓包工具今天要给大家介绍的一个Unix下的一个网络数据采集分析工具,也就是我们常说的抓包工具。与它功能类似的工具有wireshark,不同的是,wireshark有图形化界面,而tcpdump则只有命令行。由于我本人更习惯使用命令行的方式进行抓包,因此今天先跳过wireshark,直接给大家介绍这个tcpdump神器。这篇文章,我肝了好几天,借助于Linux的man帮助命令,我把tcpdump的用法全部研究了个遍,才形成了本文,不夸张的说,应该可以算是中文里把tcpdump.

    2022年10月14日
    5
  • 不止一个背包的背包问题_超级背包怎么使用方法

    不止一个背包的背包问题_超级背包怎么使用方法有 N 个物品和一个容量是 V 的背包。物品之间具有依赖关系,且依赖关系组成一棵树的形状。如果选择一个物品,则必须选择它的父节点。如下图所示:如果选择物品5,则必须选择物品1和2。这是因为2是5的父节点,1是2的父节点。每件物品的编号是 i,体积是 vi,价值是 wi,依赖的父节点编号是 pi。物品的下标范围是 1…N。求解将哪些物品装入背包,可使物品总体积不超过背包容量,且总价值最大。输出最大价值。输入格式第一行有两个整数 N,V,用空格隔开,分别表示物品个数和背包容量。接下来有 N

    2022年8月9日
    9
  • python 爱心代码_python浪漫代码

    python 爱心代码_python浪漫代码动态心型importturtleimporttimedefLittleHeart():foriinrange(200):turtle.right(1)turtle.forward(2)love=’Ilove草莓’turtle.setup(width=900,height=500)turtle.color(‘red’,’red’)turtle.pensize(3)turtle.speed(50)turtle.

    2022年10月13日
    6
  • Elasticsearch系列——实战探索text与keyword的区别

    Elasticsearch系列——实战探索text与keyword的区别前言本文使用的工具是 kibana Linux Kibana 的安装与测试 在 elasticsearc x 版本 字符串数据只有 string 类型 ES 更新到 5 版本后 取消了 string 数据类型 代替它的是 keyword 和 text 数据类型那么 text 和 keyword 有什么区别呢 我们通过下面的步骤来探索一下 step1 添加数据首先 使用 bulk 往 es

    2026年3月5日
    9

发表回复

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

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