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
}
相关推荐
李迟23 分钟前
Golang实践录:在go中使用curl实现https请求
开发语言·golang·https
Dream it possible!1 小时前
LeetCode 热题 100_寻找重复数(100_287_中等_C++)(技巧)(暴力解法;哈希集合;二分查找)
c++·leetcode·哈希算法
BUG制造机.1 小时前
Go 语言的 GMP 模型
golang
张帅涛_6661 小时前
golang读、写、复制、创建目录、删除、重命名,文件方法总结
golang
运维-大白同学1 小时前
go-数据库基本操作
开发语言·数据库·golang
你怎么知道我是队长1 小时前
GO语言语法---if语句
golang
张帅涛_6661 小时前
golang中的反射示例
golang
小羊在奋斗4 小时前
【LeetCode 热题 100】二叉树的最大深度 / 翻转二叉树 / 二叉树的直径 / 验证二叉搜索树
算法·leetcode·职场和发展
q567315235 小时前
图片爬虫通过模板及使用说明
开发语言·爬虫·tcp/ip·golang
2301_794461575 小时前
力扣-283-移动零
算法·leetcode·职场和发展