zoukankan      html  css  js  c++  java
  • java工具类-列表分段处理

    java.util.List 分段

    使用google的guava类库对List分段处理

         List<Integer> intList = Lists.newArrayList(1, 2, 3, 4, 5, 6, 7, 8);
            List<List<Integer>> subSets = Lists.partition(intList, 3);
    List<Integer> last = subSets.get(2);

      原理是内部封装着我们要分段的List的引用,在subSets.get(index) 语句时,对参数List.subList()动态处理 

    对集合的处理

            Collection<Integer> intCollection = Lists.newArrayList(1, 2, 3, 4, 5, 6, 7, 8);
            Iterable<List<Integer>> subSets = Iterables.partition(intCollection, 3);
            List<Integer> firstPartition = subSets.iterator().next();

      使用iterable进行遍历,iterator.next()方法,内部是使用固定size大小的数组循环状态size次数据,然后返回数据

    使用apache common工具的的List分段处理方法

            ArrayList<Integer> intList = Lists.newArrayList(1, 2, 3, 4, 5, 6, 7, 8);
            List<List<Integer>> subSets2 = ListUtils.partition(intList, 3);

      这个方法和guava包的列表分段方法原理是相同的

    自定义泛型方法进行分页

        /**
         * 列表数据分组
         * @param source 源数据
         * @param size 根据大小分组
         * @param <T> 泛型
         * @return
         */
        public static <T> List<List<T>>  averageAssign(List<T> source, int size){
            List<List<T>> result = new ArrayList<>();
            int offset=0;
            boolean isZero = source.size()%size==0;
            int totalPage = source.size()/size + 1;
            int totalSize = source.size();
            while(totalPage-1>=offset){
                List<T> subList = null;
                if(offset == totalPage-1){
                    if(isZero){
                        break;
                    }
                    //最后一段的处理
                    subList = source.subList(size * offset, totalSize);
                }else{
                    subList = source.subList(size * offset, size * (offset + 1));
                }
                offset++;
                result.add(subList);
            }
            return result;
        }
  • 相关阅读:
    【CQOI2015】网络吞吐量
    【SDOI2010】所驼门王的宝藏
    【NOIP2013】华容道
    【SNOI2019】通信
    【IOI2016】railroad
    【AtCoder3611】Tree MST
    【AtCoder2134】ZigZag MST
    【CF891C】Envy
    【BZOJ4883】棋盘上的守卫
    【CF888G】Xor-MST
  • 原文地址:https://www.cnblogs.com/gne-hwz/p/13255489.html
Copyright © 2011-2022 走看看