LintCode 子集

題目

給定一個含不同整數的集合,返回其所有的子集

注意事項
子集中的元素排列必須是非降序的,解集必須不包含重復的子集

樣例
如果 S = [1,2,3],有如下的解:

Paste_Image.png

代碼

class Solution {
    /**
     * @param S: A set of numbers.
     * @return: A list of lists. All valid subsets.
     */
    public ArrayList<ArrayList<Integer>> subsets(int[] num) {
        ArrayList<ArrayList<Integer>> res = new ArrayList<>();
        
        if(num == null || num.length == 0)
            return res;
        
        ArrayList<Integer> list = new ArrayList<>();
        
        Arrays.sort(num);
        
        helper(res, list, num, 0);
        return res;
    }

    private void helper(ArrayList<ArrayList<Integer>> res, ArrayList<Integer> list, int[] num, int pos) {
        
        res.add(new ArrayList<>(list));
        
        for(int i=pos;i<num.length;i++) {
            list.add(num[i]);
            helper(res, list, num, i+1);
            list.remove(list.size() - 1);
        }
        
    }
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容