二进制求和 2021.11.24

做这道题老想着用常规思路解决问题

本题两大难点:二进制数据的运算&&字符串的修改

解决方案:

1.二进制的运算问题可以先转化为十进制的运算,再将运算结果转化为二进制

2.字符串的修改没必要创建新的字符串,直接使用StringBuffer或者StringBuilder

注:

当对字符串进行修改的时候,需要使用 StringBuffer 和 StringBuilder 类。

和 String 类不同的是,StringBuffer 和 StringBuilder 类的对象能够被多次的修改,并且不产生新的未使用对象。

StringBuilder 类在 Java 5 中被提出,它和 StringBuffer 之间的最大不同在于 StringBuilder 的方法不是线程安全的(不能同步访问)。

由于 StringBuilder 相较于 StringBuffer 有速度优势,所以多数情况下建议使用 StringBuilder 类。

即:StringBuilder更快 ;StringBuffer更安全

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;public class test13 {/*** 给你两个二进制字符串,返回它们的和(用二进制表示)。* 输入为 非空 字符串且只包含数字1和0。** 示例1:* 输入: a = "11", b = "1"* 输出: "100"** 示例2:* 输入: a = "1010", b = "1011"* 输出: "10101"** 提示:* 每个字符串仅由字符 '0' 或 '1' 组成。* 1 <= a.length, b.length <= 10^4* 字符串如果不是 "0" ,就都不含前导零。** @param args*/public static void main(String[] args) throws IOException {BufferedReader br = new BufferedReader(new InputStreamReader(System.in));String a = br.readLine();String b = br.readLine();System.out.println(addBinary(a,b));}public static 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 0){ans.append('1');}return ans.reverse().toString();}
}


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部