如何填充和访问 3 维数组列表的任何元素 [英] How to populate and access any element of 3 Dimensional Array List

查看:47
本文介绍了如何填充和访问 3 维数组列表的任何元素的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要创建一个 3 维 ArrayList.

I have a requirement to create a 3-Dimensional ArrayList.

  ArrayList<ArrayList< ArrayList<Object>>> data_Header_Mapper; 

如何填充 3 D 数组列表以及如何访问 3 维 ArrayList 的叶子子节点(对象).非常感谢您的帮助.

How can i populate the 3 D arraylist and how i acccess the leaf child ( Object) of 3 Dimensional ArrayList. Lots of thanks in advance for any help.

我熟悉使用 Vectors ,但由于一些问题,我想将下面的 Vectors 代码转换为 ArrayList.填充 3D 向量的代码如下.

I am familiar working with Vectors , But due to some problems i want to convert the below code of Vectors to ArrayList. Code For Populating 3 D Vectors is as follows.

  for (int r=0;r<totalRows;r++) // r - Rows
   {

     for (int c=0;c<totalViewedCols;c++) //c- Columns
     {

       cAct=0;
       while (cAct < totalActualCols)
      // for (int cAct=0;cAct<totalActualCols;cAct++) //c- Columns
       {
         if (Cols.get(cAct).toLowerCase().equals(columnName.toLowerCase())  )
         {
          ColValindex =  colHeader_ForSave.indexOf(columnName)  ;//Temp Comment
          colValue= (String)data_ForSave.elementAt(r).get(ColValindex);
         //  ColValindex =  header.indexOf(columnName)  ;
         //  colValue= (String)data.elementAt(r).get(ColValindex);

           data_Header_Mapper_Element.add(columnName); 
           data_Header_Mapper_Element.add(colValue); 
          }
         cAct++;
       }
       if (data_Header_Mapper_Element.size() !=0)
       {
        data_Header_Mapper_Row.add(data_Header_Mapper_Element);
       // data_Header_Mapper_Element.removeAllElements();
      data_Header_Mapper_Element =null;
      data_Header_Mapper_Element=new Vector<String>();
       }
     }
      if (data_Header_Mapper_Row.size() !=0)
     {
       data_Header_Mapper.add(data_Header_Mapper_Row);

       data_Header_Mapper_Row =null;
       data_Header_Mapper_Row=new Vector<Vector<String>>();
      }

   }

访问 3D 矢量代码如下

Code For Access 3 D Vectors is below

  for(int r=0;r<rowSize;r++)
      {

      for (int c=0;c<colSize;c++)
      {

      // To Build Insert And Update Query 
           columnDataType=  dbe.GetDataTypeOfTableColumn(rsMetaData,data_Header_Mapper.elementAt(r).get(c).get(0).toString());
           dataSize=dbe.GetDataSizeOfTableColumn(rsMetaData,data_Header_Mapper.elementAt(r).get(c).get(0).toString());
           Validation.ValidateData(columnDataType, data_Header_Mapper.elementAt(r).get(c).get(1), dataSize);

         }

        }

推荐答案

public class My3DArray {

    private List<List<List<Object>>> list;

    public My3DArray() {
        this.list = generate3DArray(5, 5, 5);
    }

    public List<List<List<Object>>> generate3DArray(int dim1, int dim2, int dim3) {
        List<List<List<Object>>> list = new ArrayList<List<List<Object>>>();
        for(int i = 0; i < dim1; i++) {
            List<List<Object>> list2 = new ArrayList<List<Object>>();
            for(int j = 0; j < dim2; j++) {
                List<Object> list3 = new ArrayList<Object>(dim3);
                list2.add(list3);
            }
            list.add(list2);
        }
        return list;
    }

    public Object getElementIn3DArray(int i, int j, int k)
        throws NullPointerException, ArrayIndexOutOfBoundsException {
        return list.get(i).get(j).get(k);
    }

    public void setElementIn3DArray(Object o, int i, int j, int k)
        throws NullPointerException, ArrayIndexOutOfBoundsException {
        list.get(i).get(j).add(o);
    }
}

public class Main {
    public static void main(String[] args) {
        My3DArray x = new My3DArray();
        x.setElementIn3DArray("Hello World", 0, 0, 0);
        System.out.println(x.getElementIn3DArray(0, 0, 0));
        System.exit(0);
    }
}

我省略了类中的一些变量,如维度,但这是一个想法.如何使用这个例子取决于你.

I omit some variables in the class like the dimensions but this is an idea. Its up to you how to use this example.

这篇关于如何填充和访问 3 维数组列表的任何元素的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆