LeetCode算法题-Number Complement(Java实现-五种解法)
这是悦乐书的第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实现-五种解法)的更多相关文章
- LeetCode算法题-Number of Lines To Write String(Java实现)
这是悦乐书的第319次更新,第340篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第188题(顺位题号是806).我们要将给定字符串S的字母从左到右写成行.每行最大宽度为 ...
- LeetCode算法题-Find the Difference(Java实现-五种解法)
这是悦乐书的第214次更新,第227篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第82题(顺位题号是389).给定两个字符串s和t,它们只包含小写字母.字符串t由随机混 ...
- LeetCode算法题-Number of 1 Bits(Java实现)
这是悦乐书的第186次更新,第188篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第45题(顺位题号是191).编写一个带无符号整数的函数,并返回它所具有的"1 ...
- LeetCode算法题-Number of Boomerangs(Java实现)
这是悦乐书的第231次更新,第244篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第98题(顺位题号是447).给定平面中的n个点都是成对不同的,"回旋镖&qu ...
- LeetCode算法题-Number of Segments in a String(Java实现)
这是悦乐书的第226次更新,第239篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第93题(顺位题号是434).计算字符串中的段数,其中段定义为非空格字符的连续序列.请注 ...
- LeetCode算法题-Third Maximum Number(Java实现-四种解法)
这是悦乐书的第222次更新,第235篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第89题(顺位题号是414).给定非空的整数数组,返回此数组中的第三个最大数字.如果不存 ...
- LeetCode算法题-Missing Number(Java实现-四种解法)
这是悦乐书的第200次更新,第209篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第65题(顺位题号是268).给定一个包含n个不同数字的数组,取自0,1,2,...,n ...
- LeetCode算法题-Ugly Number(Java实现-四种解法)
这是悦乐书的第199次更新,第208篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第64题(顺位题号是263).编写一个程序来检查给定的数字是否是一个丑陋的数字.丑陋的数 ...
- LeetCode算法题-Heaters(Java实现)
这是悦乐书的第239次更新,第252篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第106题(顺位题号是475).冬天来了!您在比赛期间的第一份工作是设计一个固定温暖半径 ...
随机推荐
- 1.python简介
简介 1.python语言介绍 python的创始人:Guido Van Rossum 2.python是一门什么样的语言 编程语言主要从以下几个角度进行分类:编译型,静态型,动态性,强类型定义语言和 ...
- 死磕 java集合之HashMap源码分析
欢迎关注我的公众号"彤哥读源码",查看更多源码系列文章, 与彤哥一起畅游源码的海洋. 简介 HashMap采用key/value存储结构,每个key对应唯一的value,查询和修改 ...
- 行为驱动:Cucumber + Selenium + Java(三) - 使用标签实现测试分组
在上一篇中,我们写出了Selenium + Cucumber + Java环境下的第一个BDD自动化测试用例,这一篇我们说说怎么用标签对用例进行分组. 3.1 Cucumber标签 实际工作中,我们的 ...
- 使用mpvue开发小程序教程(六)
在上一章节中,我们列举了在Vue中能用但在mpvue中不能用或需要特别注意的特性,在实际开发前了解一下还是很有必要的,可以避免浪费找错误的时间. 如果你使用过原生的小程序框架,你一定经历过或思考过怎么 ...
- msf登陆Windows 2
使用ms17_010(永恒之蓝)进行攻击登陆(XP) 1)加载模块 2)连接靶机 3)设置payload 4)设置lhost(攻击主机IP) 5)exploit进行攻击登陆
- MySQL 笔记整理(5) --深入浅出索引(下)
笔记记录自林晓斌(丁奇)老师的<MySQL实战45讲> 5) --深入浅出索引(下) 这次的笔记从一个简单的查询开始: 建表语句是这样的 mysql> create table T ...
- MD5&&DES加密解密帮助类
public class _MD5_NETCore加密解密 { /// <summary> /// 加密 /// </summary> /// <param name=& ...
- JavaScript用法
JavaScript 用法 JavaScript 语句,会在页面加载时执行. <body> 中的 JavaScript <!DOCTYPE html> <html> ...
- [Go] golang无缓冲通道实现工作池控制并发
展示如何使用无缓冲的通道创建一个goroutine池,控制并发频率1.无缓冲通道保证了两个goroutine之间的数据交换2.当所有的goroutine都忙的时候,能够及时通过通道告知调用者3.无缓冲 ...
- 20190322-a标签、img标签、三列表、特殊字符实体、表格
目录 1.a标签 a标签的属性 锚点 2.img标签 img标签的属性 图像热区 3.三列表 有序列表(Ordered List) ol>li 无序列表(Unordered List) ...