我有2个int列表A,B和1个String列表C。它们的长度都相同。我想浏览C并删除具有相同索引的A和B条目之外的所有空字符串。因此,例如:

A:[1, 2, 3]                             A:[1, 3]

B:[4, 5, 6]        should turn into     B:[4, 6]

C:["C", "", B"]                         C:["C", "B"]


我当前的代码如下所示:

int i = 0;
for (Iterator<String> iterator = C.iterator(); iterator.hasNext();) {
    String string = iterator.next();
    if (string.isEmpty()) {
        // Remove the current element from the iterator and the list.
        iterator.remove();
        A.remove(i);
        B.remove(i);
    }
    i++;
}


但这是行不通的。

最佳答案

您可以完全避免使用索引,而可以同时遍历所有三个列表:

List<Integer> a = new ArrayList<Integer>(Arrays.asList(1,2,3));
List<Integer> b = new ArrayList<Integer>(Arrays.asList(4,5,6));
List<String> c = new ArrayList<String>(Arrays.asList("a","","c"));

Iterator<Integer> a_iterator = a.iterator();
Iterator<Integer> b_iterator = b.iterator();
Iterator<String> c_iterator = c.iterator();

while (c_iterator.hasNext() && b_iterator.hasNext() && a_iterator.hasNext()){
   a_iterator.next();
   b_iterator.next();
   String cString = c_iterator.next();
   if (cString == null || cString.isEmpty()){
     a_iterator.remove();
     b_iterator.remove();
     c_iterator.remove();
   }
}


就是说,我会尽量避免在单独的列表中处理它们。尝试使迭代器和索引保持笔直容易出错。相反,我希望有一个包含一个更复杂对象的列表来保存关联的Integers和String:

public class ABC {

private final Integer a;
private final Integer b;
private final String c;

private ABC(Integer a, Integer b, String c){
    this.a = a;
    this.b = b;
    this.c = c;
}

// Add Getters


}

这样我就可以拥有List<ABC>,并且我始终知道我拥有与每个'a'相关联的正确的'b'和'c'等。您可以遍历该列表并删除具有空白c的整个ABC。如果我控制生成列表的代码,则直接跳到List<ABC>。如果这样给我,我可能仍会合并它们,但是如果它们使用不多,我可能会按原样处理它们。不过,总的来说,我不喜欢编写代码来维护列表之间的隐式关系。

08-06 05:47
查看更多