java数组拆分多个子数组

这里做个java集合/数组拆分多个子集合/数组的两种实现方式的笔记。

方式 一:

/**
 * 拆分集合
 * @param datas
 * @param splitSize
 * @param <T>
 * @return
 */
private <T> List<List<T>> spliceArrays(List<T> datas, int splitSize) {
    if (datas == null || splitSize < 1) {
        return  null;
    }
    int totalSize = datas.size();
    //获取要拆分子数组个数
    int count = (totalSize % splitSize == 0) ?
            (totalSize / splitSize) : (totalSize/splitSize+1);

    System.out.println("split count = " +count);

    List<List<T>> rows = new ArrayList();
    for (int i = 0;i < count;i ++) {

        int index = i * splitSize;
        List<T> cols = new ArrayList();
        int j = 0;
        while (j < splitSize && index < totalSize) {
            cols.add(datas.get(index++));
            j ++;
        }
        rows.add(cols);
    }
    return rows;
}

方式二:

/**
 * 拆分集合
 * @param datas
 * @param splitSize
 * @param <T>
 * @return
 */
private <T> List<List<T>> spliceArrays(List<T> datas, int splitSize) {
    if (datas == null || splitSize < 1) {
        return  null;
    }
    int totalSize = datas.size();
    int count = (totalSize % splitSize == 0) ?
            (totalSize / splitSize) : (totalSize/splitSize+1);

    List<List<T>> rows = new ArrayList<>();

    for (int i = 0; i < count;i++) {

        List<T> cols = datas.subList(i * splitSize,
                (i == count - 1) ? totalSize : splitSize * (i + 1));
        rows.add(cols);
        System.out.println(cols);
    }
    return rows;
}
时间: 2024-11-05 19:35:40

java数组拆分多个子数组的相关文章

数组拆分为新数组

package com.classes;//已知数组a,将奇数位置元素存到b数组中,偶数位置元素存到c数组中public class Shuzu1118_4 { public static void main(String[] args) { int [] a={3,6,9,1,4,7,2,5,8}; int [] b; //定义数组b int [] c; //定义数组c//先找出数组b和数组从的长度 if(a.length%2==0){ b=new int[a.length/2]; c= ne

输入一个整形数组,数组里有正数也有负数。数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。求所有子数组的和的最大值。要求时间复杂度为O(n)

群里看到这道题,用python做了做, def find(array): v_sum = greatest = 0 for a in array: v_sum += a v_sum = 0 if v_sum < 0 else v_sum greatest = v_sum if v_sum > greatest else greatest if v_sum == 0: greatest = array[0] for a in array: greatest = a if greatest <

软件工程结对开发——返回一个整数数组中最大子数组的和(JAVA)

题目:返回一个整数数组中最大子数组的和. 要求: 输入一个整型数组,数组里有正数也有负数: 数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和: 求所有子数组的和的最大值.要求时间复杂度为O(n): 一.设计思想 1.首先随机产生一个数组,数组长度可自行输入,该数组里有正数也有负数. 2.从数组中第一个元素a[0]开始,依次计算a[0].a[0]+a[1].a[0]+a[1]+...+a[i]的值,即从a[0]开始的每个子数组的和,取出最大值. 3.再从数组第二个元素a[1]开始,依

整数数组求最大子数组和

一.实验题目 返回一个整数数组中最大子数组的和. 二.实验要求 输入一个一维整形数组,数组里有正数也有负数. 一维数组首尾相接,象个一条首尾相接带子一样. 数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和.求所有子数组的和的最大值. 三.设计思想 该实验大部分可以分为两部分: 1.利用while循环录入输入的数组值,输入值为string类型,利用Integer.parseInt(String a),存入int数组,如果是"#"则结束录入 2.调用求最大值函数和的最大值,分

求一个数组的最大子数组之和

题目: 输入一个一维整形数组,数组里有正数也有负数.一维数组首尾相接,像个一条首尾相接带子一样.数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和.求所有子数组的和的最大值. 代码: import java.util.Scanner; public class Array{ public static void main(String[] args) { System.out.print("请输入数组的长度N="); Scanner scan=new Scanner(Sys

软件工程课堂练习:返回一个一维整数数组中最大子数组的和

题目:返回一个一维整数数组中最大子数组的和.要求:输入一个一维整形数组,数组里有正数也有负数.一维数组首尾相接,象个一条首尾相接带子一样.数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和.求所有子数组的和的最大值. 此次何琳琳负责程序分析,代码编程,张一博负责代码复审和代码测试计划. 经分析讨论设计思路如下: 1.定义一个长为20的数组,先对前10个数进行初始化,后10个数等于前10个数: 2.设置长度为10的循环依次以前十个数为头进行最大子数组的计算: 3,再设置一个数组用来存储

结对开发——返回一个整数数组中最大子数组的和

一.题目要求 1.输入一个整型数组,数组里有正数也有负数. 2.数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和. 3.求所有子数组的和的最大值.要求时间复杂度为O(n). 二.设计思想 1.首先随机产生一个数组,该数组里有正数也有负数. 2.从数组中第一个元素a[0]开始,依次计算a[0].a[0]+a[1].a[0]+a[1]+...+a[i]的值,即从a[0]开始的每个子数组的和,取出最大值. 3.再从数组第二个元素a[1]开始,依次往后计算每个子数组的和,取出最大值.依次循

返回一个一维整数数组中最大子数组的和(环)

题目: 返回一个一维整数数组中最大子数组的和. 要求: 输入一个一维整形数组,数组里有正数也有负数. 一维数组首尾相接,象个一条首尾相接带子一样. 数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和. 求所有子数组的和的最大值. 设计思想: (1)存在三个一维数组.第一个用于存储 输入的数组:第二个用于存储不同子数组的最大值:第三个用于存储 起始点不同的数组的最大值. (2)1.定制输入整数的个数 2.创建第一个一维数组,将数字输入 3. 利用循环,将所存在的第一个数组的数,进行加法

求二维数组的最大子数组

一.题目: n返回一个二维整数数组中最大子数组的和. 二.要求: n输入一个二维整形数组,数组里有正数也有负数. n二维数组中连续的一个子矩阵组成一个子数组,每个子数组都有一个和. n求所有子数组的和的最大值.要求时间复杂度为O(n). 三.程序源码: import java.util.Random; import java.util.Scanner; public class dd { public static void main(String[] args) { // TODO Auto-