LeetCode每日一题1 - 1720.解码异或后的数组(Python编程)

题目名称:1720.解码异或后的数组

难度 :简单

题目描述

未知 整数数组 arr 由 n 个非负整数组成。

经编码后变为长度为 n - 1 的另一个整数数组 encoded ,其中 encoded[i] = arr[i] XOR arr[i + 1] 。例如,arr = [1,0,2,1] 经编码后得到 encoded = [1,2,3] 。

给你编码后的数组 encoded 和原数组 arr 的第一个元素 first(arr[0])。

请解码返回原数组 arr 。可以证明答案存在并且是唯一的。

示例1

输入:encoded = [1,2,3], first = 1
输出:[1,0,2,1]
解释:若 arr = [1,0,2,1] ,那么 first = 1 且 encoded = [1 XOR 0, 0 XOR 2, 2 XOR 1] = [1,2,3]

示例2

输入:encoded = [6,2,7,3], first = 4
输出:[4,2,0,7,4]

提示

  • 2 <= n <= 104
  • encoded.length == n - 1
  • 0 <= encoded[i] <= 105
  • 0 <= first <= 105

题目解析

Python位运算符

运算符描述
&按位与运算符:参与运算的两个值,如果两个相应位都为1,则该位的结果为1,否则为0
|按位或运算符:只要对应的二个二进位有一个为1时,结果位就为1
^按位异或运算符:当两对应的二进位相异时,结果为1
~按位取反运算符:对数据的每个二进制位取反,即把1变为0,把0变为1 。~x 类似于 -x-1
<<左移动运算符:运算数的各二进位全部左移若干位,由 << 右边的数字指定了移动的位数,高位丢弃,低位补0
>>右移动运算符:把">>"左边的运算数的各二进位全部右移若干位,>> 右边的数字指定了移动的位数

数学证明

异或运算的性质:

  • 相同数值异或,结果为 0
  • 任意数值与 0 进行异或,结果为数值本身
  • 异或本身满足交换律

已知 encoded[i-1] = arr[i-1] XOR arr[i],将等式两边同时「异或」arr[i-1]。可得:
encoded[i-1] XOR arr[i-1] = arr[i-1] XOR arr[i] XOR arr[i-1]
可化简得
encoded[i-1] XOR arr[i-1] = arr[i] XOR 0
故arr[i] = encoded[i-1] XOR arr[i-1]

python编程实现

class Solution:
    def decode(self, encoded: List[int], first: int) -> List[int]:
        arr = [first]
        for num in encoded:
            arr.append(arr[-1] ^ num)
        return arr

复杂度分析

  • 时间复杂度:O(n)
  • 空间复杂度:O(n)

提交结果

提交结果截图

题目总结

这道题目的求解有点像解方程,通过已知的两个数求解另一个未知数,而求解的过程中主要运用了异或运算的性质。这道题目很好的结合了逻辑思维(求证)和计算思维(模拟计算过程)。

知识拓展

  • 异或
    异或是一个数学运算符。它应用于逻辑运算。异或的数学符号为“⊕”,计算机符号为“^”。其运算法则为:a⊕b = a’b + ab’(a’为非a)
  • 同或
    同或是一个数学运算符,应用于逻辑运算。 其运算法则为:a同或b=ab+a’b’(a’为非a)
  • 可以证明同或和异或互为非运算
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值