专业网站建设经费申请报告,网站网站建设公,怎么做原创短视频网站,个人网页制作策划书1.解码异或后的数组
未知 整数数组 arr 由 n 个非负整数组成。
经编码后变为长度为 n - 1 的另一个整数数组 encoded #xff0c;其中 encoded[i] arr[i] XOR arr[i 1] 。例如#xff0c;arr [1,0,2,1] 经编码后得到 encoded [1,2,3] 。
给你编码后的数组 encoded 和原…1.解码异或后的数组
未知 整数数组 arr 由 n 个非负整数组成。
经编码后变为长度为 n - 1 的另一个整数数组 encoded 其中 encoded[i] arr[i] XOR arr[i 1] 。例如arr [1,0,2,1] 经编码后得到 encoded [1,2,3] 。
给你编码后的数组 encoded 和原数组 arr 的第一个元素 firstarr[0]。
请解码返回原数组 arr 。可以证明答案存在并且是唯一的。
方法一异或运算
#方法一异或运算
def decode(encoded,first):res[0 for i in range(len(encoded)1)]res[0]firstfor i in range(1,len(encoded)1):res[i]res[i-1]^encoded[i-1] #利用性质 encoded[i-1]res[i]^res[i-1] # encoded[i-1]^res[i-1]res[i]return res
2.找出所有子集的异或总和再求和
一个数组的 异或总和 定义为数组中所有元素按位 XOR 的结果如果数组为 空 则异或总和为 0 。
例如数组 [2,5,6] 的 异或总和 为 2 XOR 5 XOR 6 1 。 给你一个数组 nums 请你求出 nums 中每个 子集 的 异或总和 计算并返回这些值相加之 和 。
注意在本题中元素 相同 的不同子集应 多次 计数。
数组 a 是数组 b 的一个 子集 的前提条件是从 b 删除几个也可能不删除元素能够得到 a 。
方法一二进制枚举
#方法一二进制枚举
def subsetXORSum(nums):res0for i in range(0,1len(nums)):tem0for j in range(0,len(nums)): #子集100表示取出第三个数 1100以此类推if(i(1j)):tem^nums[j] #二进制枚举看这一位是不是1是1就代表是子集元素restemreturn res