首页 > 其他 > 详细

3.3---集合栈

时间:2015-12-20 14:32:08      阅读:296      评论:0      收藏:0      [点我收藏+]

思路:注意一下别写错add还是remove

public class SetOfStacks {
   public static ArrayList<ArrayList<Integer>> setOfStacks(int[][] ope, int size) {
        // write code here
        
        ArrayList<ArrayList<Integer>> res = new ArrayList();
        ArrayList<Integer> list = new ArrayList();
        
        res.add(list);
        if(ope.length == 0) return res;

        for(int i = 0; i < ope.length; i++){
            ArrayList<Integer> tmp     = null;
            if(ope[i][0] == 1){
                
                if(res.get(res.size() - 1).size() == size){
                    tmp = new ArrayList();
                }
                else{
                    tmp = res.get(res.size() - 1);
                    res.remove(res.size() - 1);
                }


                tmp.add(ope[i][1]);

                res.add(tmp);
            }
            else{
                if(res.get(res.size() -1).size() != 0){
                    tmp = res.get(res.size() - 1);
                    res.remove(res.size() - 1);
                    tmp.remove(tmp.size() - 1);
                    if(tmp.size() != 0)
                    res.add(tmp);
                }
                else{
                    res.remove(res.size() - 1);
                }
                
            }
        }

        return res;

    }
}

 

3.3---集合栈

原文:http://www.cnblogs.com/yueyebigdata/p/5060725.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!