2015-08-28 25 views
1

Java列表是否有一个从列表中选择索引子集的方法?如何获得列表的非包含子集?

例如,输入[1, 4, 5]的列表[a, b, c, d, e, f, g]应输出[a, d, e]

+0

我正在使用java 7,但java 8的方式是什么? – rossb83

+1

在Collections类中没有这样的方法,但是你可以通过使用一个简单的循环来获得它。 –

回答

4

在Java 8中这非常容易,只要确保在索引上使用流,而不是在对象上,并使用.map;

public static void main(String[] args) { 
    List<String> stringList = Arrays.asList("a", "b", "c", "d"); 
    List<Integer> indices = Arrays.asList(1, 3); 

    List<String> resultList = indices.stream() 
        .map(i -> stringList.get(i)) 
        .collect(Collectors.toList()); 

    System.out.println(resultList); 
} 

这并不难在Java 7中之一:

public static void main(String[] args) { 
    List<String> stringList = Arrays.asList("a", "b", "c", "d"); 
    List<Integer> indices = Arrays.asList(1, 3); 

    List<String> resultList = new ArrayList<>(); 

    for(int i : indices) { 
    resultList.add(stringList.get(i)); 
    } 

    System.out.println(resultList); 
} 

在这两种情况下,输出的是:只有

[b, d] 
+0

我正在寻找一种原生的方式来做到这一点,这正是我所使用的 – rossb83

0

使用一个循环与LinkedHashMap,因为没有这样的特定方法获取列表中的一个子集(索引集合类。

代码:

public static void main(String[] args) { 
     List<Character> ls = new ArrayList<Character>(); 
     ls.add('a'); 
     ls.add('b'); 
     ls.add('c'); 
     ls.add('d'); 
     ls.add('e'); 
     ls.add('f'); 
     ls.add('g'); 
//EDIT 
    int subIndex[] = new int[] { 1, 4, 5 }; 
    Map<Integer, Character> result = new LinkedHashMap<>(); 

    for (int i = 0; i < subIndex.length; i++) { 
     result.put(i, ls.get(subIndex[i] - 1)); 
    } 
    System.out.println(result.values());  
} 

输出: [a, d, e]

我希望这将有助于。

+0

其实,我认为这是'ade'的输出,而不是'[a,d,e]' – durron597

+0

@ durron597,感谢提高这一关切。这个输出是'ade'或者一个d(全都在不同的行中(println()))。 –

+0

@ durron597,请立即检查。感谢提及。 –

相关问题