加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

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

发布时间:2020-12-14 16:27:10 所属栏目:Java 来源:网络整理
导读:我正在尝试创建一个数组数组等数组…,除了我不知道它需要多少嵌套级别,直到运行时. 根据输入,我可能需要int [],int [] [],int [] [] [] [] [] []或其他任何东西. (对于上下文,我正在尝试为元胞自动机构建一个N维网格,其中N作为参数传递.) 我没有任何代码,因
我正在尝试创建一个数组数组等数组…,除了我不知道它需要多少嵌套级别,直到运行时.

根据输入,我可能需要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] ];
        }
   }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读