我有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>
。如果这样给我,我可能仍会合并它们,但是如果它们使用不多,我可能会按原样处理它们。不过,总的来说,我不喜欢编写代码来维护列表之间的隐式关系。