【问题描述】[简单]

给你两个二进制字符串,返回它们的和(用二进制表示)。输入为 非空 字符串且只包含数字 1 和 0。示例 1:输入: a = "11", b = "1"
输出: "100"
示例 2:输入: a = "1010", b = "1011"
输出: "10101"提示:每个字符串仅由字符 '0' 或 '1' 组成。
1 <= a.length, b.length <= 10^4
字符串如果不是 "0" ,就都不含前导零。

【解答思路】

1. 朴素

先将 aa 和 bb 转化成十进制数,求和后再转化为二进制数。利用 Python 和 Java 自带的高精度运算

class Solution {public String addBinary(String a, String b) {return Integer.toBinaryString(Integer.parseInt(a, 2) + Integer.parseInt(b, 2));}
}

2. 模拟


时间复杂度:O(N) 空间复杂度:O(1)

class Solution {public String addBinary(String a, String b) {StringBuffer ans = new StringBuffer();int n = Math.max(a.length(), b.length()), carry = 0;for (int i = 0; i < n; ++i) {carry += i < a.length() ? (a.charAt(a.length() - 1 - i) - '0') : 0;carry += i < b.length() ? (b.charAt(b.length() - 1 - i) - '0') : 0;ans.append((char) (carry % 2 + '0'));carry /= 2;}if (carry > 0) {ans.append('1');}ans.reverse();return ans.toString();}
}
class Solution {public String addBinary(String a, String b) {int i = a.length() - 1, j = b.length() - 1;int carry = 0;StringBuilder res = new StringBuilder();while (i >= 0 || j >= 0 || carry > 0){int x = (i >= 0) ? a.charAt(i) - '0' : 0;int y = (j >= 0) ? b.charAt(j) - '0' : 0;int sum = x + y + carry;int curr = sum % 2;carry = sum / 2;res.append(curr);i--;j--;}return res.reverse().toString();}
}
3. 位运算



class Solution:def addBinary(self, a, b) -> str:x, y = int(a, 2), int(b, 2)while y:answer = x ^ ycarry = (x & y) << 1x, y = answer, carryreturn bin(x)[2:]

java版本位运算 但测试用例位数过长时会导致失败 所以java版本的位运算长答案错误 如果字符串超过 33 位,不能转化为 Integer 如果字符串超过 65 位,不能转化为 Long 如果字符串超过 500000001位,不能转化为 BigInteger

 public String addBinary(String a, String b) {//long x= Long.parseLong(a, 2) ;   return Long.toBinaryString(x);//BigInteger x= new BigInteger(a,10) ;   大整数是是Java里的一个类 位运算无法操作int x= Integer.parseInt(a, 2) ;//二进制转十进制 int y=Integer.parseInt(b, 2);int answer =0 ,carry = 0;while(y>0){answer = x^y;carry = (x&y)<<1;x=answer;y=carry;}return Integer.toBinaryString(x);//十进制转二进制 }

【总结】

1.StringBuffer 和 StringBuilder 和String的区别

运算速度

线性安全

总结

2.BigInteger

BigInteger API
BigInteger不是基本数据类型之一,它其实更像String,是Java里的一个类,然而它的初始化方式却没有String那么方便可以直接赋值,而是跟其他自定义的类一样,要调用它的构造器进行初始化。这个类的取值范围原则上是没有上限的,取决于你的计算机的内存,它的构造器有以下几种:


常用狗崽方法BigInger(String val)

BigInteger a=new BigInteger(“2222222222222222”);

常用方法:

BigInteger abs()  返回大整数的绝对值
BigInteger add(BigInteger val) 返回两个大整数的和
BigInteger and(BigInteger val)  返回两个大整数的按位与的结果
BigInteger andNot(BigInteger val) 返回两个大整数与非的结果
BigInteger divide(BigInteger val)  返回两个大整数的商
double doubleValue()   返回大整数的double类型的值
float floatValue()   返回大整数的float类型的值
BigInteger gcd(BigInteger val)  返回大整数的最大公约数
int intValue() 返回大整数的整型值
long longValue() 返回大整数的long型值
BigInteger max(BigInteger val) 返回两个大整数的最大者
BigInteger min(BigInteger val) 返回两个大整数的最小者
BigInteger mod(BigInteger val) 用当前大整数对val求模
BigInteger multiply(BigInteger val) 返回两个大整数的积
BigInteger negate() 返回当前大整数的相反数
BigInteger not() 返回当前大整数的非
BigInteger or(BigInteger val) 返回两个大整数的按位或
BigInteger pow(int exponent) 返回当前大整数的exponent次方
BigInteger remainder(BigInteger val) 返回当前大整数除以val的余数
BigInteger leftShift(int n) 将当前大整数左移n位后返回
BigInteger rightShift(int n) 将当前大整数右移n位后返回
BigInteger subtract(BigInteger val)返回两个大整数相减的结果
byte[] toByteArray(BigInteger val)将大整数转换成二进制反码保存在byte数组中
String toString() 将当前大整数转换成十进制的字符串形式
BigInteger xor(BigInteger val) 返回两个大整数的异或

既然不是基本数据类型,所以大数的加减乘除也不能使用+、-、*、/这些运算符号,Java也没有对这些运算符号进行重定义,取而代之的是用一些方法来代替,比如add()、subtract()、mutiply()、divide()这四种方法,它们的使用举例如下:

3. 一个没有遍历完 一个遍历完 使用三元运算符 carry进位思想

参考链接:https://leetcode-cn.com/problems/add-binary/solution/er-jin-zhi-qiu-he-by-leetcode-solution/

参考链接:https://leetcode-cn.com/problems/add-binary/solution/guan-fang-ti-jie-fang-fa-er-xiang-jie-bu-shi-yong-/

参考链接:https://leetcode-cn.com/problems/add-binary/solution/java-lei-si-lian-biao-qiu-he-by-kelly2018/

参考链接:https://blog.csdn.net/qushaming/article/details/82971901

参考链接:https://www.jianshu.com/p/8b89ab19db84

[Leedcode][JAVA][第67题][二进制求和][位运算][字符串]相关推荐

  1. LeetCode题库第67题二进制求和

    题目描述:给你两个二进制字符串,返回它们的和(用二进制表示).输入为 非空 字符串且只包含数字 1 和 0. 题解思路: 把二进制字符串转换成数组这样便于运算 把数组元素进行倒转,最后再把运算结果倒转 ...

  2. python二进制移位_python学习特辑——二进制和位运算篇

    以前学习java的时候,二进制和位运算只停留在"懂"的程度,从来没有花时间去推导和总结,作为一个数学系的学生,一直想花点时间做推理证明 java和python关于二进制和位运算的规 ...

  3. [Leedcode][JAVA][第45题][跳跃游戏 II][贪心算法]

    [问题描述][Leedcode][JAVA][第45题][跳跃游戏 II] 输入: [2,3,1,1,4] 输出: 2 解释: 跳到最后一个位置的最小跳跃数是 2.从下标为 0 跳到下标为 1 的位置 ...

  4. [Leedcode][JAVA][第105题][从前序与中序遍历序列构造二叉树][栈][递归][二叉树]

    [问题描述][中等] 根据一棵树的前序遍历与中序遍历构造二叉树.注意: 你可以假设树中没有重复的元素.例如,给出前序遍历 preorder = [3,9,20,15,7] 中序遍历 inorder = ...

  5. [Leedcode][JAVA][第470题][Ran7()实现Rand10()]

    [问题描述][Leedcode][JAVA][第470题][Ran7()实现Rand10()] 已有方法 rand7 可生成 1 到 7 范围内的均匀随机整数,试写一个方法 rand10 生成 1 到 ...

  6. java 二进制位运算_Java中的二进制与位运算

    大家在阅读一些算法或者一些开源框架的时候,总会见到~,>>,>>>,|这种大量的位运算,因此想要读明白 这部分代码,对于计算机的二进制操作以及位运算是必须要了解的,那么本 ...

  7. 7、Java四种进制及位运算介绍

    7.Java四种进制及位运算介绍 四种进制: 二进制:0,1 以0b或0B开头 十进制:0-9 八进制:0-7 以数字0开头 十六进制:0-9 及A(10)-F(15) ,以0x或0X开头,此处A-F ...

  8. 超有趣的二进制—高效位运算秒懂

    附Java/C/C++/机器学习/算法与数据结构/前端/安卓/Python/程序员必读书籍书单大全: 书单导航页(点击右侧 极客侠栈 即可打开个人博客):极客侠栈 ①[Java]学习之路吐血整理技术书 ...

  9. [Leedcode][JAVA][第136题][第137题][只出现一次的数字][位运算][HashSet][HashMap]

    [问题描述][第136,137题][只出现一次的数字] 给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现了N次.找出那个只出现了一次的元素.[第136题]N= 2 输入: [2,2 ...

最新文章

  1. 接受者操作特征曲线ROC
  2. Aveiconifier是一个非常实用方便的制作ico格式文件的小工具~
  3. 关闭rdlc报表打印预览后,关闭客户端,抛出异常“发生了应用程序级的异常 将退出”...
  4. Berkeley DB——Records
  5. intellij 快捷键整理
  6. LiveVideoStack线上交流分享 ( 七) —— 舞台现场直播技术实践
  7. java中无法推断类型参数_Java 10中的本地类型推断,或者如果它像鸭子一样嘎嘎叫...
  8. HDU 6319(单调队列)
  9. linux的jdk、tomcat、tomcat安装等
  10. MATLAB希尔伯特Hilbert变换求包络谱
  11. 打字练习网站keybr.com
  12. windows 用浏览器打开应用程序的方法
  13. ubuntu 安裝deb_ubuntu安装deb
  14. docker-1 常用命令
  15. 教你有效清理C盘空间不足的方法
  16. win10巨帧数据包在哪里设置_电脑和路由器mtu值怎样设置才网速最快
  17. C++ 模板的显示具体化
  18. 怎么使用大疆无人机建模?
  19. 百度网盘网页版增加倍速播放速度
  20. 恒星物联-河道流量监测系统方案 流量监测

热门文章

  1. Android中的一些基础知识(二)
  2. 各种推荐资料汇总。。。
  3. VS 2012 找回消失的“创建单元测试”
  4. 怎么用c语言实现万年历,用C语言如何编写“万年历”
  5. ORACLE SGA问题分析
  6. common lisp 学习第四天 变量、宏
  7. flash调用摄像头弹出设置框监听
  8. 如何使用用window.open()
  9. python3 while循环语句_python While 循环语句
  10. Android之Notification初识