这是悦乐书的第240次更新,第253篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第107题(顺位题号是476)。给定正整数,输出其补码数。补充策略是翻转其二进制表示的位。例如:

输入:5

输出:2

说明:5的二进制表示为101(无前导零位),其补码为010,因此需要输出2。

输入:1

输出:0

说明:1的二进制表示形式为1(无前导零位),其补码为0,因此需要输出0。

注意:

  • 保证给定的整数适合32位有符号整数的范围。

  • 您可以假设整数的二进制表示中没有前导零位。

本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。

02 第一种解法

先将正整数转为二进制字符串,然后变成字符数组,将其中的0变成1,1变成0,再将字符数组变为字符串,最后将字符串转为二进制数。

public int findComplement(int num) {
String str = Integer.toBinaryString(num);
char[] arr = str.toCharArray();
for (int i=0; i<arr.length; i++) {
if (arr[i] == '0') {
arr[i] = '1';
} else {
arr[i] = '0';
}
}
return Integer.parseInt(String.valueOf(arr), 2);
}

03 第二种解法

我们可以仔细观察题目所给的示例:

5表示的二进制数为101,最后的结果是2,所表示的二进制数为10,如果我们将其前导0补齐,就会发现101通过计算后要得到010,那么需要借助怎样的计算呢?

借助位运算,101^111 = 010,我们使用二进制数111和101做异或运算就可以得到最后的结果。

因此,我们需要获取num表示的二进制数长度,来组成一个由1组成新二进制数(长度和num表示的二进制数一致),再将两数做异或运算即可。

异或运算的规则是两边的对应位不同时,取1,否则取0。

public int findComplement2(int num) {
String str = Integer.toBinaryString(num);
String str2 = "";
for (int i=0; i<str.length(); i++) {
str2 += "1";
}
int res = Integer.parseInt(str2, 2);
return num^res;
}

04 第三种解法

还是第二种解法的思路,只不过将字符串操作换为了位运算操作,我们先将num右移,计算其二进制数有多少位,记为i,然后再对1进行左移i位,移完后得到的二进制数是1个1加上i个0,而不是i个1,所以我们需要减去1使其变成i个1,最后和num做异或运算并返回其结果。

public int findComplement3(int num) {
if (num == 0) {
return 1;
}
int i = 0;
while ((num>>i) != 0) {
i++;
}
int res = (1<<i)-1;
return num^res;
}

05 第四种解法

还是第二种解法的思路,与第三种解法的位运算不同,借助包装类和位运算来一起完成计算,Integer类的highestOneBit方法,取的是其二进制数左侧的最高位1,因为本题的输入参数为正数,可以不用考虑负数、反码、补码的问题。获得最高位所表示的整数后,再左移一位,然后再减1,最后还是和num进行异或运算,并返回结果。

public int findComplement4(int num) {
if (num == 0) {
return 1;
}
int res = (Integer.highestOneBit(num)<<1) - 1;
return num^res;
}

06 第五种解法

还有一种做法,也借助位运算,使用与(&)运算,在进行与运算之前,我们先要把与运算两边的数准备好。左边的数是对num进行非运算,右边的数还是需要借助Integer类的highestOneBit方法,获取最高位1所表示的整数再减去1,然后两个新的数进行与运算,并返回结果。以题目中的5为例:

左边:对5进行非运算,得到-6

右边:5的二进制数最高位1表示为整数4,减去1为3

3

00000000000000000000000000000011

-6

10000000000000000000000000001010

当相同的位上均为1时结果为1,否则结果为0

00000000000000000000000000000010

也就是整数2。

public int findComplement5(int num) {
return ~num & (Integer.highestOneBit(num) - 1);
}

07小结

算法专题目前已日更超过三个月,算法题文章107+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

LeetCode算法题-Number Complement(Java实现-五种解法)的更多相关文章

  1. LeetCode算法题-Number of Lines To Write String(Java实现)

    这是悦乐书的第319次更新,第340篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第188题(顺位题号是806).我们要将给定字符串S的字母从左到右写成行.每行最大宽度为 ...

  2. LeetCode算法题-Find the Difference(Java实现-五种解法)

    这是悦乐书的第214次更新,第227篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第82题(顺位题号是389).给定两个字符串s和t,它们只包含小写字母.字符串t由随机混 ...

  3. LeetCode算法题-Number of 1 Bits(Java实现)

    这是悦乐书的第186次更新,第188篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第45题(顺位题号是191).编写一个带无符号整数的函数,并返回它所具有的"1 ...

  4. LeetCode算法题-Number of Boomerangs(Java实现)

    这是悦乐书的第231次更新,第244篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第98题(顺位题号是447).给定平面中的n个点都是成对不同的,"回旋镖&qu ...

  5. LeetCode算法题-Number of Segments in a String(Java实现)

    这是悦乐书的第226次更新,第239篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第93题(顺位题号是434).计算字符串中的段数,其中段定义为非空格字符的连续序列.请注 ...

  6. LeetCode算法题-Third Maximum Number(Java实现-四种解法)

    这是悦乐书的第222次更新,第235篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第89题(顺位题号是414).给定非空的整数数组,返回此数组中的第三个最大数字.如果不存 ...

  7. LeetCode算法题-Missing Number(Java实现-四种解法)

    这是悦乐书的第200次更新,第209篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第65题(顺位题号是268).给定一个包含n个不同数字的数组,取自0,1,2,...,n ...

  8. LeetCode算法题-Ugly Number(Java实现-四种解法)

    这是悦乐书的第199次更新,第208篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第64题(顺位题号是263).编写一个程序来检查给定的数字是否是一个丑陋的数字.丑陋的数 ...

  9. LeetCode算法题-Heaters(Java实现)

    这是悦乐书的第239次更新,第252篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第106题(顺位题号是475).冬天来了!您在比赛期间的第一份工作是设计一个固定温暖半径 ...

随机推荐

  1. 【干货】基于Owin WebApi 使用OAuth2进行客户端授权服务

    前言:采用Client Credentials方式,即密钥key/password,场景一般是分为客户端限制必须有权限才能使用的模块,这和微信公众号开放平台很类似. 让用户通过客户端去获取自己的tok ...

  2. 手把手用Monkey写一个压测脚本

    版权声明: 本账号发布文章均来自公众号,承香墨影(cxmyDev),版权归承香墨影所有. 允许有条件转载,转载请附带底部二维码. 一.为什么需要一个测试脚本? 昨天讲解了Android Monkey命 ...

  3. 设计模式总结篇系列:策略模式(Strategy)

    前面的博文中分别介绍了Java设计模式中的创建型模式和结构型模式.从本文开始,将分别介绍设计模式中的第三大类,行为型模式.首先我们了解下分为此三大类的依据. 创建型模式:主要侧重于对象的创建过程: 结 ...

  4. PC逆向之代码还原技术,第六讲汇编中除法代码还原以及原理第二讲,被除数是正数 除数非2的幂

    目录 一丶简介 二丶代码还原讲解 1.被除数无符号 除数非2的幂 2.被除数无符号 除数为特例7 三丶代码还原总结 一丶简介 上一篇博客说的除2的幂. 如果被除数是有符号的,那么会进行调整,并使用位操 ...

  5. Java开发知识之XML文档使用,解析

    目录 XML文件详解 一丶XML简介 1.文档结构 2.XML中的元素(Element)或者叫做标签(Tab).属性 文本内容. 节点(Node) 3.XML语法规则 二丶XML文档解析 三丶使用XP ...

  6. Eclipse工具常用快捷键

    Eclipse工具常用快捷键 一丶文件菜单常用快捷键 新建  Alt + shift + N 关闭当前编辑器 Ctrl +W 全部关闭 Ctrl + shift + w 保存  Ctrl + s 刷新 ...

  7. RDIFramework.NET ━ .NET快速信息化系统开发框架 V3.2->Web版本新增新的角色授权管理界面效率更高、更规范

    角色授权管理模块主要是对角色的相应权限进行集中设置.在角色权限管理模块中,管理员可以添加或移除指定角色所包含的用户.可以分配或授予指定角色的模块(菜单)的访问权限.可以收回或分配指定角色的操作(功能) ...

  8. 使用微软PinYinConverter查询汉字拼音

    通过汉字,如何查询拼音? 微软有相应的DLL可直接使用 引用方式 Nuget包管理安装 DLL下载后,引用 可以从微软的网站上下载相关文字处理的类库,下载地址如下: http://download.m ...

  9. HAProxy负载均衡技术

    软件负载均衡一般通过两种方式来实现:基于操作系统的软负载实现和基于第三方应用的软负载实现.LVS就是基于Linux操作系统实现的一种软负载,HAProxy就是开源的并且基于第三应用实现的软负载. HA ...

  10. WPF 中图片的加载 ,使用统一资源标识符 (URI)

    在wpf中,设置图片路径有2种方法: 1.xaml文件中,指定路径 <Button Name=" HorizontalAlignment="Right" Verti ...