LeetCode刷题1863-简单-找出所有子集的异或和

Posted 布小禅

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode刷题1863-简单-找出所有子集的异或和相关的知识,希望对你有一定的参考价值。

☀️ 前言 ☀️

算法作为极其重要的一点,是大学生毕业找工作的核心竞争力,所以为了不落后与人,开始刷力扣算法题!

🙀 作者简介 🙀

大家好,我是布小禅,一个尽力让无情的代码变得生动有趣的IT小白,很高兴能偶认识你,关注我,每天坚持学点东西,我们以后就是大佬啦!

📢 博客主页:❤布小禅❤
📢 作者专栏:
❤Python❤
❤Java❤

❤力扣题❤

这是我刷第 55/100 道力扣简单题

💗 一、题目描述 💗

一个数组的 异或总和 定义为数组中所有元素按位 XOR 的结果;如果数组为 空 ,则异或总和为 0 。
例如,数组 [2,5,6] 的 异或总和 为 2 XOR 5 XOR 6 = 1 。
给你一个数组 nums ,请你求出 nums 中每个 子集 的 异或总和 ,计算并返回这些值相加之 和 。
注意:在本题中,元素 相同 的不同子集应 多次 计数。
数组 a 是数组 b 的一个 子集 的前提条件是:从 b 删除几个(也可能不删除)元素能够得到 a

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/sum-of-all-subset-xor-totals
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

示例1:

输入:nums = [1,3]
输出:6
解释:[1,3] 共有 4 个子集:
- 空子集的异或总和是 0- [1] 的异或总和为 1- [3] 的异或总和为 3- [1,3] 的异或总和为 1 XOR 3 = 20 + 1 + 3 + 2 = 6

示例2:

输入:nums = [5,1,6]
输出:28
解释:[5,1,6] 共有 8 个子集:
- 空子集的异或总和是 0- [5] 的异或总和为 5- [1] 的异或总和为 1- [6] 的异或总和为 6- [5,1] 的异或总和为 5 XOR 1 = 4- [5,6] 的异或总和为 5 XOR 6 = 3- [1,6] 的异或总和为 1 XOR 6 = 7- [5,1,6] 的异或总和为 5 XOR 1 XOR 6 = 20 + 5 + 1 + 6 + 4 + 3 + 7 + 2 = 28

提示:1 <= nums.length <= 12
1 <= nums[i] <= 20

💁 二、题目解析 💁

思 路 1 : \\color{green}{思路1:} 1

使用位运算

🏃 三、代码 🏃

☁️ 1️⃣. python ☁️

class Solution:
    def subsetXORSum(self, nums: List[int]) -> int:
        ans = 0
        n = len(nums)
        for i in nums:
            ans |= i
        return ans<<(n-1)

❄️ 2️⃣. C# ❄️

public class Solution {
    public int SubsetXORSum(int[] nums) {
        int ans = 0;
        int n = nums.Length-1;
        foreach (int i in nums)
        {
            ans |= i;
        }
        return ans<<n;
    }
}

🌔 结语 🌔

坚持最重要,每日一题必不可少!😸

期待你的关注和督促!😛

以上是关于LeetCode刷题1863-简单-找出所有子集的异或和的主要内容,如果未能解决你的问题,请参考以下文章

1863. 找出所有子集 的异或总和 再求和回溯

算法学习1863. 找出所有子集的异或总和再求和(java / c / c++ / python / go / rust)

算法学习1863. 找出所有子集的异或总和再求和(java / c / c++ / python / go / rust)

Leetcode刷题Python78. 子集

通过位操作来遍历子集 leetcode题5759

通过位操作来遍历子集 leetcode题5759