1. ホーム

[解決済み】Java:ArrayListを複数の小さなArrayListに分割するにはどうすればよいですか?

2022-04-04 19:07:54

質問

1つのArrayList(size=1000)を同じサイズ(=10)の複数のArrayListに分割するにはどうすればよいですか?

ArrayList<Integer> results;

解決方法は?

を使用することができます。 subList(int fromIndex, int toIndex) を使えば、元のリストの一部を表示させることができます。

APIから

<ブロッククオート

このリストの、指定した fromIndex を含み、かつ toIndex は、排他的である。(もし fromIndextoIndex が等しい場合、返されるリストは空です)。返されたリストは、このリストによってバックアップされているので、返されたリストの非構造的な変更は、このリストに反映され、その逆もまた同様です。返されたリストは、このリストがサポートしているすべてのオプションのリスト操作をサポートしています。

List<Integer> numbers = new ArrayList<Integer>(
    Arrays.asList(5,3,1,2,9,5,0,7)
);

List<Integer> head = numbers.subList(0, 4);
List<Integer> tail = numbers.subList(4, 8);
System.out.println(head); // prints "[5, 3, 1, 2]"
System.out.println(tail); // prints "[9, 5, 0, 7]"

Collections.sort(head);
System.out.println(numbers); // prints "[1, 2, 3, 5, 9, 5, 0, 7]"

tail.add(-1);
System.out.println(numbers); // prints "[1, 2, 3, 5, 9, 5, 0, 7, -1]"

もし、これらの刻んだリストがビューでないことが必要なら、単に新しい List から subList . これをいくつか並べた例がこちらです。

// chops a list into non-view sublists of length L
static <T> List<List<T>> chopped(List<T> list, final int L) {
    List<List<T>> parts = new ArrayList<List<T>>();
    final int N = list.size();
    for (int i = 0; i < N; i += L) {
        parts.add(new ArrayList<T>(
            list.subList(i, Math.min(N, i + L)))
        );
    }
    return parts;
}


List<Integer> numbers = Collections.unmodifiableList(
    Arrays.asList(5,3,1,2,9,5,0,7)
);
List<List<Integer>> parts = chopped(numbers, 3);
System.out.println(parts); // prints "[[5, 3, 1], [2, 9, 5], [0, 7]]"
parts.get(0).add(-1);
System.out.println(parts); // prints "[[5, 3, 1, -1], [2, 9, 5], [0, 7]]"
System.out.println(numbers); // prints "[5, 3, 1, 2, 9, 5, 0, 7]" (unmodified!)