Golang | Leetcode Golang题解之第90题子集II

题目:

题解:

Go 复制代码
func subsetsWithDup(nums []int) (ans [][]int) {
    sort.Ints(nums)
    n := len(nums)
outer:
    for mask := 0; mask < 1<<n; mask++ {
        t := []int{}
        for i, v := range nums {
            if mask>>i&1 > 0 {
                if i > 0 && mask>>(i-1)&1 == 0 && v == nums[i-1] {
                    continue outer
                }
                t = append(t, v)
            }
        }
        ans = append(ans, append([]int(nil), t...))
    }
    return
}
相关推荐
Morwit20 分钟前
【力扣hot100】 416. 分割等和子集
数据结构·c++·算法·leetcode·职场和发展
宵时待雨44 分钟前
优选算法专题3:二分查找
数据结构·c++·算法·leetcode·职场和发展
@小柯555m1 小时前
算法(字母异位词分组)
java·开发语言·算法·leetcode
cpp_25011 小时前
P1877 [HAOI2012] 音量调节
数据结构·c++·算法·动态规划·题解·洛谷·背包dp
木子墨5161 小时前
LeetCode 热题 100 精讲 | 矩阵与图论进阶篇:矩阵置零 · 螺旋矩阵 · 旋转图像 · 搜索二维矩阵 II · 岛屿数量 · 腐烂的橘子
c++·算法·leetcode·矩阵·力扣·图论
米粒12 小时前
力扣算法刷题 Day 52
算法·leetcode·职场和发展
Tomhex2 小时前
Go泛型实战:类型参数化应用
golang
小雅痞2 小时前
[Java][Leetcode hard] 68. 文本左右对齐
java·开发语言·leetcode
AnYU_12 小时前
布隆过滤器(BloomFilter)
golang·bloomfilter·shorturl
6Hzlia2 小时前
【Hot 100 刷题计划】 LeetCode 102. 二叉树的层序遍历 | C++ 极简 DFS 巧解
c++·leetcode·深度优先