【二进制转换】十进制 转 二进制 (含相关题型)

布满荆棘的人生 2023-10-14 10:29 60阅读 0赞

在这里插入图片描述

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~
个人主页:.29.的博客
学习社区:进去逛一逛~

十进制 转 二进制

      1. &运算符 介绍
      1. << 运算符 介绍
      1. 十进制 转 二进制
      1. 面试题 05.06. 整数转换 - 力扣(LeetCode)

1. &运算符 介绍

& 运算符,也称为按位与运算符,是一种位运算符。它用于对两个整数进行位运算,并生成一个新的整数,其中每个对应位上的值只有在两个操作数对应位上都为 1 的情况下才为 1,否则为 0。

按位与运算符使用符号“&”表示。它逐位比较两个操作数的每一位,并根据下面的规则生成结果:

  • 如果两个操作数的对应位都为 1,则结果的对应位为 1。
  • 如果两个操作数的对应位之一为 0,则结果的对应位为 0。

换句话说,只有当两个操作数的对应位上都为 1 时,结果才为 1。否则,结果为 0。

示例:

假设我们有两个二进制数:10111001 和 11001100。使用按位与运算符将它们进行位运算,结果是 10001000,它是两个操作数的对应位进行按位与运算得到的值。

  1. 10111001
  2. & 11001100
  3. 10001000

2. << 运算符 介绍

<< 运算符是一种位左移运算符,用于将一个整数的所有位向左移动指定的位数。

左移运算符将二进制数的所有位向左移动,并在右侧用零填充。每一次的左移操作都会使操作数乘以 2 的 n 次幂,其中 n 是左移的位数。

示例

假设我们有一个整数 x = 5,用二进制表示为 00000101,我们可以使用左移运算符将其向左移动两位,结果为 00010100,用十进制表示为 20。

  1. x = 5 << 2;

3. 十进制 转 二进制

  1. public class s01 {
  2. //转换、打印
  3. public static void print(int num) {
  4. //遍历32位(int在底层就是通过32位二进制存储的。)
  5. for(int i = 31;i >= 0;--i) {
  6. //通过 &运算 获得num的二进制形式
  7. //1 << 1 —— 二进制:0010
  8. //1 << 2 —— 二进制:0100
  9. //1 << 3 —— 二进制:1000
  10. System.out.print((num & (1 << i)) == 0?"0":"1");
  11. }
  12. System.out.println();
  13. }

注意:

    1. int在底层就是通过32位二进制存储的。

4. 面试题 05.06. 整数转换 - 力扣(LeetCode)

题目
在这里插入图片描述

作答

  1. class Solution {
  2. public int convertInteger(int A, int B) {
  3. int ans = 0;
  4. //遍历获取二进制形式的32个数位
  5. for(int i = 0;i < 32;++i){
  6. int a = (A & (1 << i));
  7. int b = (B & (1 << i));
  8. //遇到不相同的数位,就是需改变的数位
  9. if(a != b) ++ans;
  10. }
  11. return ans;
  12. }
  13. }

在这里插入图片描述


在这里插入图片描述

发表评论

表情:
评论列表 (有 0 条评论,60人围观)

还没有评论,来说两句吧...

相关阅读

    相关 十进制转换二进制

    输入一个十进制的数,将其转换为二进制!!(也适用于八进制!当然,代码中的2就要变为8了) (如有错误,欢迎提出) //十进制转换为二进制