JAVA 对字符串类型的二进制编码进行反码、补码操作

对字符换类型的二进制编码进行反码、补码操作

例:求-5的补码。

-5对应正数5(00000101)→所有位取反(11111010)→加1(11111011)

所以-5的补码是11111011。

 

/**
 * 反码
 *String s="00000101"
 *结果 11111010
 */
public static String InvertedCode(String  s){
    StringBuilder sr = new StringBuilder(s);
    for (int i = 0; i < sr.length(); i++) {
        if (sr.substring(i,i+1).equals("0")){
            sr.replace(i,i+1,"1");
        }else{
            sr.replace(i,i+1,"0");
        }
    }
    return sr.toString();
}
/**
 * 补码
 * String st="11111010"
 *  结果 11111011
 */
public static String Complement(String st) {
    StringBuilder sr = new StringBuilder(st);
    if (st.substring(st.length() - 1).equals("0")) {
        sr.replace(st.length() - 1, st.length(), "1");
        return sr.toString();
    } else {
        sr.replace(st.length() - 1, st.length(), "0");
        for (int i = st.length() - 1; i > 0; i--) {
            if (st.substring(i - 1, i).equals("0")) {
                sr.replace(i - 1, i, "1");
                return sr.toString();
            } else {
                sr.replace(i - 1, i, "0");
            }
        }
        return sr.toString();

    }

}

 

以上针对 java 二进制 字符串的格式,方便解析一些二进制、十六进制、负值 之间的转换操作。

纯java代码,有其他的方法可以留言评论。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值