为了账号安全,请及时绑定邮箱和手机立即绑定

字符串的二进制加法

字符串的二进制加法

月关宝盒 2023-07-13 14:20:55
我需要组合一个字符串数组,如下所示(因此结果字符串中的每个字符都是输入字符串中字符的按位 & )String a = "10110001"String b = "01101101"String c = "10101011"String result = "00100001"我想出的解决方案:long resultLong = 0;for( String a : inputs ){    resultLong = resultLong & Long.parseLong( a ,2);}String result = Long.toBinaryString( resultLong );输入字符串中的字符数可能非常长,并且上述解决方案不起作用 (NumberFormatException) 。我不知道如何实现这一点,最干净的方法是什么?
查看完整描述

2 回答

?
qq_笑_17

TA贡献1818条经验 获得超7个赞

如果 Long 不足以满足您的用例,那么您可以使用BigInteger


BigInteger(String val, int radix);

它以字符串和基数作为参数。


BigInteger result = new BigInteger(inputs[0], 2);


for (int i = 1; i < inputs.length; i++) {

    result = result.and(new BigInteger(inputs[i], 2));

}


String resultStr = result.toString(2);


查看完整回答
反对 回复 2023-07-13
?
忽然笑

TA贡献1806条经验 获得超5个赞

这是你的算法。这适用于任意数量的 ,Strings前提是所有Strings 的长度相同:


public static void main(String[] args) {

    String a = "10110001";

    String b = "01101101";

    String c = "10101011";


    String arr[] = new String[]{a, b, c};


    String finalString = "";

    for (int i = 0; i < arr[0].length(); i++) {

        int temp = Integer.parseInt("" + arr[0].charAt(i));

        for (int j = 1; j < arr.length; j++) {

            temp = temp & Integer.parseInt("" + arr[j].charAt(i));

        }

        finalString += temp;

    }

    System.out.println(finalString);

}

输出/输出


00100001


查看完整回答
反对 回复 2023-07-13
  • 2 回答
  • 0 关注
  • 94 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信