繁体   English   中英

从数组中打印唯一值

[英]print unique values from array

我需要获取第一个数组索引的唯一值,这就是我尝试的方法。

public class Array {

    public static void main(String[] args) {

        int[][] array = { 
                  {100, 12 , 0, 3},
                  {100, 177, 0, 3},
                  {100, 233, 0, 3}, 
                  {100, 144242, 0, 3},
                  {100, 14, 0, 4},  
                  {100, 12234, 0, 4},
                  {100, 134, 1, 4},
                  {2, 15, 0, 3},
                  {23, 1533, 0, 3},
                  {23, 1322, 1, 4}, 
                  {23, 13, 1, 4}, 
                  {23, 122, 1, 4},
                  {1321, 142, 1, 4},
                  {1321, 133,1, 4},
                  {3, 16, 0, 5},
                  {55, 1003, 0,3},
                  {553, 1002, 2, 6},
                  {31, 162, 0, 5},
                  {7, 1626, 0, 5},
                  {7, 2336, 0,5}           
                 };




        boolean isUnique = true;

        for(int i=0; i<= array.length; i++)
        {
             for (int j = 0; j < 1; j++)
             {
                 if (array[j]==array[j])
                 {                       

                     int riid = array[i][j];    

                     Set<Integer> uniqueNumbers = new HashSet<Integer>(Arrays.asList(riid));

                     System.out.println(riid);
                 }               
             }
         }
    }
}

我的输出必须是100、2、23、1321、3、55、553、31和7。但是,它没有给我唯一的值。 打印1001001001001001002 2 23 23 23 23 1321 1321 3 55 553 31 7 7

如何获得此输出的唯一值。 我认为Set<Integer> uniqueNumbers = new HashSet<Integer>(Arrays.asList(riid)); 有助于。 但是,事实并非如此。

您只需要写:

    Set<Integer> uniqueNumbers = new LinkedHashSet<Integer>();
    for (int i = 0; i < array.length; i++) {
        uniqueNumbers.add(array[i][0]);
    }
    System.out.println(uniqueNumbers);

您的代码中有很多问题:

  • i <= array.length -Java中的数组从零开始
  • 您的内部循环从0到1,您到底要在这里实现什么?
  • 您将在每次迭代中覆盖集合,这与您想要的不完全相同

对于您的问题,有许多可能的解决方案,其中一种是将2D数组展平(对于Java 8来说很简单),然后将其转换为Set

int[] myArr = Arrays.stream(array)
            .flatMapToInt(Arrays::stream)
            .toArray();

Set<Integer> mySet = new HashSet<>(Arrays.asList(myArr));

这很简单,创建一个ArrayList并检查它是否包含每个数组的第一个元素,然后不将该元素添加到ArrayList中,如果不包含它,则将其添加到ArrayList中。

 ArrayList<Integer> list = new ArrayList<>();
      for(int i = 0 ; i < array.length ;i++ ){
              if(!list.contains(array[i][0])){
                  list.add(array[i][0]);
              }
      }

是工作实例

此条件比较相同的值,因此将始终为真:

if (array[j]==array[j])
//        ↑         ↑

以我的理解,您只需要检查第一个位置:

int lastRiid = 0;

for (int i = 0; i < array.length; i++) {
    if (array[i][0] != lastRiid) {
        lastRiid = array[i][0];
        System.out.println(lastRiid);
    }
}

OUTPUT:

100
2
23
1321
3
55
553
31
7

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM