如何在java中创建任意深度的嵌套数组?

我正在尝试创建一个数组数组等数组…,除了我不知道它需要多少嵌套级别,直到运行时.

根据输入,我可能需要int [],int [] [],int [] [] [] [] [] []或其他任何东西. (对于上下文,我正在尝试为元胞自动机构建一个N维网格,其中N作为参数传递.)

我没有任何代码,因为我不知道如何去做;我怀疑只使用数组是不可能的.任何帮助或替代解决方案,将不胜感激.

解决方法

您可以使用Object []执行此操作,将其成员限制为Object []或int [].

例如,这是一个数组,在一个部分中有三个深度,在另一个部分中有两个深度:

Object[] myarray = new Object[] {
         new Object[] { new int[] { 1,2 },new int[] { 3,4 }},new int[] { 5,6 } 
    };

创建后,您可能想要访问成员.在您的情况下,您知道前面的深度N,因此您知道期望Object []的深度以及期望int []的深度.

但是,如果您不知道深度,则可以使用反射来确定成员是另一个Object []级别还是叶子int [].

if ( myarray[0] instanceof Object[] ) {
           System.out.println("This should print true.");
    }

编辑:

这是一个草图[目前为止未经测试,对不起]一个方法,在给定索引数组的情况下访问已知深度数组的成员. m_root成员可以是Object []或int []. (您可以进一步放松以支持标量.)

public class Grid {
        private int m_depth;
        private Object m_root;
        ...
        public int get( int ... indices ) {
            assert( indices.length == m_depth );
            Object level = m_root;
            for ( int i = 0; i + 1 < m_depth; ++i ) {
                level = ((Object[]) level)[ indices[i] ];
            }
            int[] row = (int[]) level;
            return row[ indices[m_depth - 1] ];
        }
   }

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...