Подсписок Arraylist в Android - PullRequest
       62

Подсписок Arraylist в Android

2 голосов
/ 02 марта 2012

Я хочу добавить в список arraylist и хранить его в небольших arraylists.

Я делаю следующее, но не могу ввести точные значения в маленьких массивах. Пожалуйста, посмотрите мой код и предложите другой способ или скажите, что я делаю неправильно

ArrayList<ques_details> queslist = new ArrayList<ques_details>();

ArrayList[] resgrp = new ArrayList[queslist.size() / 2];
Log.v("length", resgrp.length + "");

for (int i = 0; i < resgrp.length ; i++) {
    resgrp[i] = new ArrayList();
    Log.v("initialised ", i + "");
}

for (int i = 0; i <= queslist.size()-1 ; i++) {
    resgrp[i].add(queslist.get(i));
    Log.v("final ", resgrp[i].size() + "");
}

РЕДАКТИРОВАТЬ:

public void subListArray(int start, int end) {
        // Log.v("queslist size", queslist.size() + "");
        int m = queslist.size();
        // Log.v("m", m + "");
        ArrayList[] resgrp = new ArrayList[m / 2];
        // Log.v("length", resgrp.length + "");
        int n = resgrp.length;
        // Log.v("n", n + "");
        int o = m / n;
        // Log.v("o", o + "");
        for (int i = 0; i < n; i++) {
            resgrp[i] = new ArrayList<String>();
            Log.v("initialised ", i + "");
        }
        ArrayList<String> TempList = new ArrayList<String>();
        for (int i = start; i <= end - 1; i++) {
            int q = 0 ;
            String temp = queslist.get(i).Ques;
            resgrp[o].add(q, temp);
            // resgrp[i].add(queslist.get(i));
            Log.v("final ", queslist.get(i).Ques + "");
            TempList = resgrp[o];
            q++;
            adapter = new ArrayAdapter(E_Learning_AppActivity.this,
                    R.layout.list_item, R.id.text, TempList);
        }
    }

Ответы [ 2 ]

6 голосов
/ 02 марта 2012

Короткий ответ

Я бы предложил вам использовать либо:

Длинный ответ + Примеры

Использование Google Guava Lists.partition(List, int)

Это разделит ваши List на List s указанного int размера:

List<Stuff> l = new ArrayList<Stuff>();

// [...] populate l with Stuff here [...]

// partitioning:
List<List<Stuff>> ll = Lists.partition(l, 5);
// you now have a list containing sub-lists of at most 5 elements

Примечания:

  • Используется List.subList для внутреннего использования (см. Ниже).
  • Возвращает вид! (возможно, вы захотите сделать копии).

Используйте стандарт JDK List.subList(int, int)

package com.stackoverflow.haylem.sublists;

import java.util.ArrayList;
import java.util.List;

public class SubLists {

  public static <T> List<List<T>> partition(List<T> l, final int nPartitions) {
    final List<List<T>> partitions = new ArrayList<List<T>>(nPartitions);
    final int           nElements  = l.size() / nPartitions; // number of elements per full partition
    final int           nRest      = l.size() % nElements;   // size of the last partition (if any)

    for (int i = 0; i < nPartitions; i++) { // create our nPartitions partitions
      partitions.add(l.subList(             // one subList per partition
          i * nElements,
          i * nElements + nElements
      ));
    }
    if (nRest > 0) {                        // remainder sublist
      partitions.add(l.subList(
          nPartitions * nElements,
          (nPartitions * nElements) + nRest));
    }
    return (partitions);
  }

  /**
   * Generates a dummy list for testing
   */
  public static List<String>      generateStringList(final int size) {
    final List<String> data = new ArrayList<String>(size);

    for (int i = 0; i < 129; i++) {
      data.add("String " + i);
    }
    return (data);
  }

  /**
   * Prints out all the sublists to visualize partitioning
   */
  public static <T> void          printSubLists(final List<List<T>> sLists) {
    for (int i = 0; i < sLists.size(); i++) { // iterates over all sublists
      System.out.println("partition " + i);
      for (final T element : sLists.get(i)) { // prints out current sublist
        System.out.println(" " + element);    // prints out current element
      }
    }
  }

  public static void              test() {
    final List<String> data = generateStringList(129);

    // splits l in five partitions and
    // prints out 5 partitions of 25 elements and 1 of 4
    printSubLists(partition(data, 5));

    // splits l in partitions of 4 or less elements and
    // prints out 32 partitions of 4 elements and 1 of 1
    printSubLists(partition(data, data.size() / 4));
  }

}

Примечания:

  • Вам нужно будет самостоятельно рассчитать размеры (это облегчает Гуава).
    • Спасите себя и используйте Guava.
  • Возвращает вид! (возможно, вы захотите сделать копии).

Дополнительное чтение и другие методы

4 голосов
/ 02 марта 2012

Вы создаете queslist.size() / 2 списки для хранения «подсписков»

ArrayList[] resgrp = new ArrayList[queslist.size() / 2];
                                   ^^^^^^^^^^^^^^^^^^^

, но вы пытаетесь заполнить их до queslist.size() во втором цикле:

for (int i = 0; i <= queslist.size()-1; i++) {
                     ^^^^^^^^^^^^^^^^^

    resgrp[i].add(queslist.get(i));
           ^

Либо создайте больше списков массивов, либо не пытайтесь получить доступ к такому количеству из них: -)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...