0

[[58, 89, -50], [58, 50, -89], [89, 50, -58], [-51, -35, 75], [-51, -75, 35], [-35, -75, 51], [-83, -60, -97], [-83, 97, 60], [-60, 97, 83], [null]]

在上面的例子中,LinkedHashSet<Integer> [size<N><3>]有 N 号。整数对象,每个对象包含 3 个原始 int 值。我想在三个不同的 int 类型列表中访问它,以便我得到

list1[1] : {58,58,89,-51,.......}
list2[1] : {89,50,50,-35,.......}
list3[1] : {-50,-89,-58,75.......}

正如我在 C 语言中所做的那样,让 P 指向我们访问的第一个节点

struct Node *P=Start;
int i=0;
while(P!=NULL){
int a[i]=P->data1;
int b[i]=P->data2;
int c[i]=P->data3;
i++;}

在 Java 中会怎样。请帮助我。谢谢!Ashish

4

2 回答 2

0

您可以实现 3 个不同的 Lists 。最简单的方法就是编写一个覆盖 java.util.AbstractList<E> http://docs.oracle.com/javase/6/docs/api/java/util/AbstractList.html的类并从 3 元素列表中选择一个元素。

这是您的解决方案:

import java.util.ArrayList;

public class DemuxList extends java.util.AbstractList<Integer>{

    ArrayList<Integer[]> listToDemux;
    int listIndex;

    DemuxList(ArrayList<Integer[]> listToDemux, int listIndex) {
        this.listToDemux = listToDemux;
        this.listIndex = listIndex;
    }

    @Override
    public Integer get(int index)
    {
        Integer[] el = listToDemux.get(index);
        if (el != null) {
            return el[listIndex];
        } else {
            return null;
        }        
    }

    @Override
    public int size()
    {
        return listToDemux.size();
    }
}

你可以这样使用它:

ArrayList<Integer[]> fullList = new ArrayList<Integer[]>();
DemuxList l0 = new DemuxList(fullList, 0);
DemuxList l1 = new DemuxList(fullList, 1);
DemuxList l2 = new DemuxList(fullList, 2);
于 2012-05-31T07:55:07.087 回答
0

我解决了这个问题,代码如下。鉴于

LinkedHashSet<Set<Integer>> r;
i=0
for(<Set<Integer>> set:r)
    ar[i++]=s.toArray(new Integer[3]);

其中 ar 是一个大小为 3 的二维数组,[r.length][3]因为 r 中的内部集合的大小为 3。

于 2012-06-25T07:12:12.690 回答