8

我想知道是否可以从 ArrayList 中的最后一个元素迭代到第一个元素,如果可以的话怎么做?原因是因为我需要删除添加到列表中的最后一个元素

4

5 回答 5

23

虽然你总是可以迭代你ArrayList使用索引,像这样

List<String> myList = new ArrayList<String>();
... add code to populate the list with some data...
for (int i = myList.size() - 1 ; i >= 0 ; i--) {
    if (myList.get(i).equals("delete me")) {
        myList.remove(i);
    }
}

你最好使用 aListIterator<T>来删除你的项目ArrayList

ListIterator<String> listIter = myList.listIterator();
while (listIter.hasNext()) {
    if (listIter.next().equals("delete me")) {
        listIter.remove();
    }
}

列表迭代器也可用于向后迭代您的列表——像这样:

ListIterator<String> listIter = myList.listIterator(myList.size());
while (listIter.hasPrevious()) {
    String prev = listIter.previous();
    // Do something with prev here
}

迭代器的初始索引应该等于最后一个元素的索引 + 1。正如文档所说:“初始调用previous将返回具有指定索引减一的元素。”

于 2013-10-07T20:00:29.230 回答
8

这是一种方法(您的原因是一个单独的问题):

import java.util.*;

List<String> list = new ArrayList<String>();
list.add("a");
list.add("b");
list.add("c");

ListIterator<String> iter = list.listIterator(list.size());

while (iter.hasPrevious()) {
    String s = iter.previous();
    System.out.println(s);
}
于 2013-10-07T20:01:56.300 回答
1

如果您只需要删除数组列表的最后一个元素,您可以这样做:

arrayList.remove(arrayList.size()-1);

如果你想从后到前删除所有元素,你可以使用这个 for 循环:

for(int i = arraList.size()-1; i >= 0; i--)
{
       arrayList.remove(i);
}

有关数组列表的更多信息,您可以访问此处:http ://www.tutorialspoint.com/java/java_arraylist_class.htm

希望这可以帮助。

于 2013-10-07T20:00:07.453 回答
0
ArrayList aList = new ArrayList();
aList.add(1);
aList.add(2);
aList.add(3);

Collections.reverse(aList);

Iterator iter = aList.iterator();
while(iter.hasNext()){
    iter.next();
    iter.remove();//remove an element
    break;//break from the loop or something else
}
于 2013-10-07T20:04:25.180 回答
0
List<String> names = ....
int count= names.getSize();
Iterator<String> i = names.iterator();
while (i.hasNext()) {
   String s = i.next(); // must be called before you can call i.remove()
   // Do something
   if (count==1)
      i.remove();
   count--;
}
于 2013-10-07T20:12:01.770 回答