Fixed XOR (将两个等长的十六进制字符串进行异或)。

一、题目描述

编程实现两个等长的十六进制字符串的异或,如果你的程序能正确运行,就可以将如下的前面两个字符串异或成第三个字符串:

1c0111001f010100061a024b53535009181c

… after hex decoding, and when XOR’d against:

686974207468652062756c6c277320657965

… should produce:

746865206b696420646f6e277420706c6179

二、算法思想

十六进制的异或实质是二进制的异或,所以先将十六进制转为十进制,十进制的异或运算实质上就是它所对应的二进制的异或,得到十进制结果,最后将十进制转化为二进制。

三、代码

#include <stdio.h> 

#include <string.h> 

#include <math.h> 

int char2int(char input)              

{

    return input>64?(input-55):(input-48);

}

int int2char( char input )           

{

    return input>9?(input+55):(input+48);

}

void hexstrxor( char * HexStr1, char * HexStr2, char
*result)

{

    int i, length,iHexStrLenGap;

    strupr(
HexStr1 );

    strupr(
HexStr2 );

    length=
strlen( HexStr1 );

    for( i=0; i<length; i++ ) 

    {

        *(result+
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
十六进制字符串按位或运算是一种常用的运算操作,可以用于数据加密、错误检测等领域。在Java中,我们可以通过使用BitSet和字符串转换为十六进制来实现该功能。 首先,我们可以将十六进制字符串转换为二进制表示,然后再进行按位或运算。可以使用Integer类的parseInt方法来将十六进制字符串转换为整型,然后使用Integer.toBinaryString方法将其转换为二进制表示。 接下来,我们可以使用BitSet类创建一个位集合,将转换后的二进制字符串按位存储到位集合中。可以使用BitSet.set方法将指定位置的位设置为指定的值。需要注意的是,位集合的大小应该与二进制字符串的长度相匹配。 然后,我们可以定义一个用于进行按位或运算的方法。可以使用BitSet类的xor方法来实现按位或运算。该方法将对位集合的每个位执行按位或运算,并返回一个新的位集合。 最后,我们可以将位集合转换回二进制字符串,并使用Integer.parseInt方法将其转换为十六进制字符串。 以下是一个示例代码片段,可以用于实现十六进制字符串按位或运算的工具类: ``` import java.util.BitSet; public class HexXorTool { public static String xorHexStrings(String hexString1, String hexString2) { int int1 = Integer.parseInt(hexString1, 16); int int2 = Integer.parseInt(hexString2, 16); String binary1 = Integer.toBinaryString(int1); String binary2 = Integer.toBinaryString(int2); int maxLength = Math.max(binary1.length(), binary2.length()); BitSet bits1 = new BitSet(maxLength); BitSet bits2 = new BitSet(maxLength); for (int i = 0; i < binary1.length(); i++) { if (binary1.charAt(i) == '1') { bits1.set(i); } } for (int i = 0; i < binary2.length(); i++) { if (binary2.charAt(i) == '1') { bits2.set(i); } } BitSet result = bits1.xor(bits2); String binaryResult = result.toString(); int intResult = Integer.parseInt(binaryResult, 2); String hexResult = Integer.toHexString(intResult); return hexResult; } public static void main(String[] args) { String hexString1 = "A5"; String hexString2 = "3C"; String xorResult = xorHexStrings(hexString1, hexString2); System.out.println("Hex XOR Result: " + xorResult); } } ``` 该工具类可以接受两个十六进制字符串作为输入,并返回经过按位或运算后的十六进制字符串。当我们在main方法中运行该代码时,将输出按位或运算的结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值