正确有效地阅读元素列明智的方法

时间:2016-07-16 10:36:56

标签: java

  

我无法找到正确读取元素列的正确方法。

输入是一个包含10个列表的列表,这10个列表包含具有可变列大小的元素

我做了什么

任务1:将10个列表添加到单个列表中。

任务2:查找列可以具有的最大大小,以便我可以将循环应用到该列。

任务3     检索List ColumnWise。

代码:  //任务1将10个列表添加到SingleList

    List<List<Integer>> outer=new ArrayList<>();
    ArrayList<Integer> innerSize=new ArrayList<Integer>();
    List<Integer> inner=null;
     int ar[][]=new int[10][];
     int ar1[] =new int[ar.length];
      for(int i=0;i<10;i++)
      {
          System.out.println("Enter the Size of the list "+i);
             String s1=sc.next();

             int N=Integer.parseInt(s1); //Calculate the Size:
              inner=new ArrayList<Integer>();
              innerSize.add(N);
         for(int j=0;j<N;j++)
         {
              System.out.println("Enter the Elements of the list "+i);

           inner.add(Integer.parseInt(sc.next()));
         }
         System.out.println(inner);
         outer.add(inner);
      }
      System.out.println(outer);

      Task 2 
      System.out.println("Finding the maximum element");
      Integer max=null;
     Iterator<Integer> ltr=innerSize.listIterator();
      if(ltr.hasNext())
      {
          Integer element=(Integer)ltr.next();
             max=element;
            while(ltr.hasNext())
            {
                Integer element1=(Integer)ltr.next();
                if(element1>max)
                {
                    max=element1;
                }
            }
      }
      System.out.println("Maximum Element is"+max);

     //Task 3
      //Retrieving the List ColumnWise.
      Iterator ltr1=outer.listIterator();

      for(int j=0;j<max;j++)
      {

              while(ltr1.hasNext())
              {
                  List l0tol9=(List)ltr1.next(); //I have one list taken from the 10 lists.
                  Iterator ltr2=l0tol9.listIterator();
                    while(ltr2.hasNext())
                    {
                        Integer i1=(Integer)ltr2.next();
                        if(i1!=null)
                        {
                            System.out.println(i1);
                            break;
                        }
                    }
              }

          }

输入:假设我从用户那里得到了这个列表:(具有最大列大小2的outerList)

[[1], [1], [1, 2], [1], [1], [1], [1], [1], [1], [1]] //outerlist

预期产出    是

1
1  
1
1
1
1
1
1
1
1
2

显示的输出:(仅第1列)

1
1
1
1
1
1
1
1
1
1

1 个答案:

答案 0 :(得分:1)

这是一种按列方式浏览二维列表的简便方法:

int maxColSize = outer.stream().mapToInt(List::size).max().orElse(0);
for (int y=0; y<maxColSize; y++) {
    for (int x=0; x<outer.size(); x++) {
        List<Integer> currentInner = outer.get(x);
        if (currentInner.size() > y) {
            System.out.println(currentInner.get(y));
        }
    }
}

您可以尝试here

如果您不能使用Java8,请将第一行替换为以下内容:

int maxColSize=0;
for (List<Integer> row : outer) { maxColSize = Math.max(maxColSize, row.size()); }