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

该博客介绍了如何实现两个等长的十六进制字符串的异或运算。通过将十六进制转换为二进制,进行异或操作,然后将结果转换回十六进制,可以得到预期的异或结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、题目描述

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

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+i)
= char2int( HexStr1[i] ) ^ char2int( HexStr2[i] ); 

        *(result+i)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值