A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© Huberry 中级黑马   /  2014-8-24 07:40  /  11879 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

如题:

public static  void fillDemo(List<String> list, int start, int end)
        {
                while (start<end)
                {
                        list.remove(start);
                        end--;
                }
                System.out.println(list);
        }
首先,我知道可以用循环一个个的删除,但是假如List元素特别多呢,这么删除不是效率很差,有没有效率高点的方法呢?

可能有人会说把要删除的部分用subList( start, end)取出来,然后用remove(collection) 来删除,可是这样的话List不想删除的部分含有与subList(start , end)中相同的元素的话,也会被删除掉。

3 个回复

倒序浏览
come 求解答
回复 使用道具 举报
既然无法那样删除可以这样
boolean retainAll(Collection<?> c)
          仅在列表中保留指定 collection 中所包含的元素(可选操作)。
回复 使用道具 举报
这个貌似可以用链表吧,List的长处本来就是查询而非删除和增加
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马