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
}
相关推荐
Han.miracle3 小时前
数据结构——二叉树的从前序与中序遍历序列构造二叉树
java·数据结构·学习·算法·leetcode
QX_hao5 小时前
【Go】--map和struct数据类型
开发语言·后端·golang
Swift社区9 小时前
LeetCode 401 - 二进制手表
算法·leetcode·ssh
派大星爱吃猫9 小时前
顺序表算法题(LeetCode)
算法·leetcode·职场和发展
Tony Bai12 小时前
释放 Go 的极限潜能:CPU 缓存友好的数据结构设计指南
开发语言·后端·缓存·golang
h79971013 小时前
go资深之路笔记(九)kafka浅析
笔记·golang·kafka
Yeats_Liao14 小时前
Go Web 编程快速入门 02 - 认识 net/http 与 Handler 接口
前端·http·golang
千码君201614 小时前
Go语言:关于导包的两个重要说明
开发语言·后端·golang·package·导包
linruicong15 小时前
题解:洛谷-P8548 小挖的买花
题解
Pluchon16 小时前
硅基计划4.0 算法 二叉树深搜(DFS)
java·数据结构·算法·leetcode·深度优先·剪枝