Subsets

这道题虽然不用到helper,但是却是那一路的

参考code 包括有helper的 http://blog.csdn.net/linhuanmars/article/details/24286377

public class Solution {
    public ArrayList<ArrayList<Integer>> subsets(int[] S) {
        ArrayList<ArrayList<Integer>> res = new ArrayList<ArrayList<Integer>>();
        if(S==null || S.length==0) return res;
        Arrays.sort(S); //!!!
        ArrayList<Integer> item = new ArrayList<Integer>();
        res.add(item);
        for(int i=0; i<S.length;i++){
            int len = res.size(); // to accelerate 
            for(int j=0;j<len;j++){// 通过控制res size,保证不出现2,3 & 3,2
                ArrayList<Integer> t = new ArrayList<Integer>(res.get(j)); // 这里一定要new 一个新的array list,否则就会指回去 AL .. t = res.get(j)
                t.add(S[i]);
                res.add(t);
            }
        }
        return res;
    }
}

 

posted @ 2015-04-16 11:55  世界到处都是小星星  阅读(191)  评论(0编辑  收藏  举报