02.位运算--异或的用法

02.位运算–异或的用法

练习题:

leetcode 习题 136.
只出现一次的数字

给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
尝试使用位运算解决此题。

"""
Input file
example1: [2,2,1]
example2: [4,1,2,1,2]

Output file
result1: 1
result2: 4
"""



class Solution:
    def singleNumber(self, nums: List[int]) -> int:
        
     # your code here
解答

异或的规律:

  • 任何数与自身异或结果为 0。
  • 任何数与 0 异或结果为本身。
代码
class Solution(object):
    def singleNumber(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        c = 0
        for x in nums:
            c ^= x
        return c
l1 = [1, 2, 2]
l2 = [4, 1, 2, 1, 2]
s = Solution()
s.singleNumber(l1)
# 1
s.singleNumber(l2)
# 4
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值