数据结构(Java)--位运算

前言

本文为本小白学习数据结构的笔记,将以算法题为导向,向大家更清晰的介绍数据结构相关知识(算法题都出自B站马士兵教育------左老师的课程,讲的很好,对于想入门刷题的人很有帮助)

为什么要使用为位运算

位运算 直接对整数的二进制位进行操作,因为在计算机中数据都是以二进制存储的,因此它在许多场景下能够提供比传统算术和逻辑运算更高效、更简洁的解决方案。

常见的几种位运算

1.位与&

复制代码
十进制转二进制 两个都为1则为1,否则为0

例:判断奇偶数:x&1=1(x为奇数 ) x&1=0(x为偶数)

2.位或|

复制代码
十进制转二进制 两个都为0则为0,否则为1

3.异或^

复制代码
十进制转二进制 两个数都相同为0,否则为1

(满足交换律,相同的数异或位0,任何数和0异或都等于这个数本身)

4.按位取反~

复制代码
变为二进制后,0变1,1变0,高位不足取0

5.左移 x<<y

复制代码
变为二进制后,x左移y位,补零。相当于乘二。

6.右移 x>>y

复制代码
变为二进制后,x右移y位,x为非负数高位补零,为负数高位补1。

例:(x+y)>>1右移一位相当于除以二

下面列几个比较好玩的运算的例子

1. 实现a与b值的交换
java 复制代码
//实现a与b值的交换

    a = a ^ b;
    b = a ^ b;    //  b=a^b^b=a
    a = a ^ b;    //  a=a^b^b
2. 想查x第n位是否为1:x&(1<<n)
3.把x的第n位设置为1/0;

为1

为0

4.取出x最右位的1

eor=eor & (~eor + 1)

5.在一个int arr[] 数组中,一种数出现了奇数次,其余树出现偶数次

(1)找到出现奇数次的数

(2)如果两种数出现奇数次,其他偶数次,怎样找到这两种数

要求时间复杂度O(n),空间O(1)

java 复制代码
//第一问
//所有数全部异或运算得出
public static void Num1(int[] arr){
    int eor = 0;
    for (int cur : arr) {
        eorr ^= cur;
    }
    System.out.println(eor);
}
java 复制代码
//第二问
//假设两个出现奇数次的数为a和b,将所有数全部异或得出eor=a^b
public static void Num2(int[] arr){
    int eor = 0;
    for (int cur : arr) {
        eorr ^= cur;
    }
    //eor 必有一位上是1
    int rightOne = eor & (~eor + 1);//取出最右位的1
    
    int onlyOne = 0;
    for(int aur : arr){
       if((aur & rightOne) == 0) {
           onlyOne ^= aur;
       }
    }
    System.out.println(onlyOne + " " +(eor^onlyOne));
}
相关推荐
Boilermaker19926 小时前
[Java 并发编程] Synchronized 锁升级
java·开发语言
Cherry的跨界思维6 小时前
28、AI测试环境搭建与全栈工具实战:从本地到云平台的完整指南
java·人工智能·vue3·ai测试·ai全栈·测试全栈·ai测试全栈
MM_MS6 小时前
Halcon变量控制类型、数据类型转换、字符串格式化、元组操作
开发语言·人工智能·深度学习·算法·目标检测·计算机视觉·视觉检测
꧁Q༒ོγ꧂7 小时前
LaTeX 语法入门指南
开发语言·latex
njsgcs7 小时前
ue python二次开发启动教程+ 导入fbx到指定文件夹
开发语言·python·unreal engine·ue
alonewolf_997 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
一嘴一个橘子7 小时前
spring-aop 的 基础使用(啥是增强类、切点、切面)- 2
java
sheji34167 小时前
【开题答辩全过程】以 中医药文化科普系统为例,包含答辩的问题和答案
java
古城小栈7 小时前
Rust 迭代器产出的引用层数——分水岭
开发语言·rust
ghie90907 小时前
基于MATLAB的TLBO算法优化实现与改进
开发语言·算法·matlab