位运算__

news/2023/6/6 5:06:04

异或运算

相同为0,不同为1,相当于无进位相加

0 ^ N = N

N ^ N = 0

异或运算满足交换律和结合律

一、打印一个数的二进制

题目

打印一个数的二进制

代码

package bitoperation;public class PrintBinary {public static void printBinary(int num) {for (int i = 32; i > 0; i--) {System.out.print((num & (1 << i)) == 0 ? '0' : '1');}}
}

二、用位运算实现+ - * /

题目

用位运算实现+ - * /

代码

package class05;// 测试链接:https://leetcode.com/problems/divide-two-integers
public class Code03_BitAddMinusMultiDiv {public static int add(int a, int b) {int sum = a;while (b != 0) {sum = a ^ b;b = (a & b) << 1;a = sum;}return sum;}public static int negNum(int n) {return add(~n, 1);}public static int minus(int a, int b) {return add(a, negNum(b));}public static int multi(int a, int b) {int res = 0;while (b != 0) {if ((b & 1) != 0) {res = add(res, a);}a <<= 1;b >>>= 1;}return res;}public static boolean isNeg(int n) {return n < 0;}public static int div(int a, int b) {int x = isNeg(a) ? negNum(a) : a;int y = isNeg(b) ? negNum(b) : b;int res = 0;for (int i = 30; i >= 0; i = minus(i, 1)) {if ((x >> i) >= y) {res |= (1 << i);x = minus(x, y << i);}}return isNeg(a) ^ isNeg(b) ? negNum(res) : res;}public static int divide(int a, int b) {if (a == Integer.MIN_VALUE && b == Integer.MIN_VALUE) {return 1;} else if (b == Integer.MIN_VALUE) {return 0;} else if (a == Integer.MIN_VALUE) {if (b == negNum(1)) {return Integer.MAX_VALUE;} else {int c = div(add(a, 1), b);return add(c, div(minus(a, multi(c, b)), b));}} else {return div(a, b);}}
}

三、不用中间变量交换俩个数的值

题目

不用中间变量交换俩个数的值

代码

package bitoperation;public class SwapTwoNum {public void swapTwoNum(int num1, int num2) {//设num1 = x,num2 = y//则num1 = x ^ ynum1 = num1 ^ num2;//则num2 = x ^ y ^ y = xnum2 = num1 ^ num2;//则num1 = x ^ y ^ x = ynum1 = num1 ^ num2;}
}

四、找到出现奇数次的数

题目

在一个数组中,有一个数出现了奇数次,其他数都出现了偶数次,找出这个数

代码

package bitoperation;public class EvenTimesOddTimes {public int evenTimesOddTimes(int[] arr) {int num = 0;for (int i = 0; i < arr.length; i++) {num ^= arr[i];}return num;}
}

原理

0 ^ N = N

N ^ N = 0

异或运算满足交换律和结合律

五、找到一个数二进制形式的最右边的1

题目

给定一个int类型的数,找到这个数二进制形式的最右边的1,并返回只有这位上有1其他位上为0的二进制对应的十进制数

代码

package bitoperation;public class FindRightOne {public int findRightOne(int num) {return num & (-num);}
}

六、找到数组中出现过奇数次的两个数

题目

一个数组中有两种数出现了奇数次,其他数都出现了偶数次,怎么找到并打印这两种数

代码

package bitoperation;public class _6FindTwoNum {public void findTwoNum(int[] arr) {int num = 0;for (int i = 0; i < arr.length; i++) {num ^= arr[i];}//假设求得两个数为a和b//num现在等于 a ^ b//找到num最右边的1//此位上a和b必定有一个为1,一个不为1,a和b等价,假设a为1int one = num & (-num);int num2 = 0;for (int i = 0; i < arr.length; i++) {if ((arr[i] & one) != 0) {num2 ^= arr[i];}//得到的是a最右边的1的位数相等的所有数异或操作//右因为其它数都是出现过偶数次//所以num2 = aint b = num ^ num2;System.out.println(num2 + " " + b);}}
}

七、找到出现了K次的数

题目

在一个数组中,一个数出现了K次,其它数都是出现了M次,0<K<M,现给出数组和M,请返回出现了K次的数的值

代码

package bitoperation;public class _7KM {public int km(int[] arr, int K, int M) {int[] myarr = new int[32];for (int i = 0; i < arr.length; i++) {for (int j = 0; j < 32; j++) {//如果arr的第0位的数的二进制的第j位为1,则记录在myarr[j]中myarr[j] += (arr[i] >> j) & 1;//相当于//if ((myarr[i] & (1 << j)) != 0) {//    myarr[i]++;//}}}int num = 0;for (int i = 0; i < 32; i++) {if (myarr[i] % M != 0) {num |= (1 << i);}}return num;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.exyb.cn/news/show-4559064.html

如若内容造成侵权/违法违规/事实不符,请联系郑州代理记账网进行投诉反馈,一经查实,立即删除!

相关文章

3D-SKIPDENSESEG医学图像分割

蓝色三角、黄色三角、红色三角相对应。 得到第三个feature map&#xff0c;绿色反卷积会恢复到原来的尺寸 Dense block&#xff0c;通道增加了 Transition&#xff0c;池化 用正则表达式把里面的h5文件匹配一下吧 os.path.join()把两个部分的路径拼一下 root_path —data_trai…

实验六 医学图像的增强(二)

动动你的修手&#xff0c;给姐姐一键三连 医学图像的锐化和伪彩色处理 一、实验目的 了解图像的锐化和伪彩色处理的Matlab实现方法。熟悉医学图像的伪彩色处理的相关方法&#xff0c;体会图像彩色处理技术及其对图像处理的效果。掌握标准方法边缘提取函数的使用方法。 二、实…

医学图像预处理(二)——重采样(resampling)

之所以需要重采样是由于不同的病人体型不同&#xff0c;但最后数字成像的分辨率是一样的&#xff0c;这就导致了一定程度的失真变形。 但医学图像例如dcm或nii格式&#xff0c;都会带有SliceThickness&#xff0c;PixelSpacing类似的属性&#xff0c;可以利用这些属性去尽量还原…

【算法】图像处理在医学领域的应用

这些方面形成此领域的三个主要过程——图像形成、图像计算和图像管理。医疗图像处理是一个非常复杂的跨学科领域&#xff0c;涵盖从数学、计算 机科学到物理学和医学的众多科学学科。 分析法的典型示例包括广泛用于断层扫描的滤波反投影&#xff08;FBP&#xff09;&#xff…

最大后验估计(MAP)------贝叶斯学派的法宝

本文讲一讲贝叶斯学派的法宝------最大后验估计(MAP) 学派背景 目前在统计分析领域存在两大学派&#xff0c;即频率学派和贝叶斯学派&#xff0c;它俩的争吵由来已久。目前国内大部分的医学统计学教材都是基于频率学派的&#xff0c;但近年来贝叶斯学派也越来越多的被大家提及…

人脸检测——mAP的含义

1 致谢 感谢网友生活不只*眼前的苟且的帮助&#xff0c; 原文链接如下&#xff1a; https://blog.csdn.net/u011734144/article/details/79985917 2 前言 今天在阅读FaceBoxes的论文~ 读的时候有的地方没有看懂&#xff0c;就是评测指标这里&#xff0c; 这里使用了一个指…

导热系数/热阻测试--美信检测

转自&#xff1a;http://mttlab.com/g/testing/thermal_conductivity/ 热阻 热量在热流路径上传递时遇到的阻力&#xff0c;反映介质或介质间的传热能力的大小&#xff0c;表明了1W的热量在1m2的面积内所引起的温升大小&#xff0c;单位为m2K/W或m2℃/W。 热导率&#xff08;导…

代码随想录--链表相关题目整理

代码随想录–链表相关题目整理 1. LeetCode203 移除链表中指定元素 给你一个链表的头节点 head 和一个整数 val &#xff0c;请你删除链表中所有满足 Node.val val 的节点&#xff0c;并返回 新的头节点 。 示例 1&#xff1a; 输入&#xff1a;head [1,2,6,3,4,5,6], val…