IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 【JavaSE】List 接口和常用方法 -> 正文阅读

[数据结构与算法]【JavaSE】List 接口和常用方法

1. List 接口基本介绍

  • List接口是 Collection 接口的子接口
  1. List集合类中元素有序(即添加顺序和取出顺序一致),且可重复。
	//1.List集合类中元素有序(即添加顺序和取出顺序一致),且可重复。
	List list = new ArrayList();
	list.add("xdr");
	list.add("mike");
	list.add("jack");
	list.add("lucy");
	list.add("lucy");
	System.out.println("list=" + list);

在这里插入图片描述

  1. List集合中的每个元素都有其对应的顺序索引,即支持索引。
	//1.List集合类中元素有序(即添加顺序和取出顺序一致),且可重复。
	List list = new ArrayList();
	list.add("xdr");
	list.add("mike");
	list.add("jack");
	list.add("lucy");
	list.add("lucy");
	System.out.println("list=" + list);
	//2.List集合中的每个元素都有其对应的顺序索引,即支持索引。
	// 索引是从 0 开始的
	System.out.println(list.get(0));//xdr
  1. List容器中的元素都对应一个整数型的序号记载其在容器中的位置,可以根据序号存取容器中的元素。【如上】
  1. JDK API中List接口的实现类有:
    在这里插入图片描述
    常用的有:ArrayList、LinkList和Vector

2. List 接口的常用方法

  • List集合里添加了一些根据索引来操作集合元素的方法
  1. void add(int index, Object ele):在index位置插入ele元素
	List list = new ArrayList();
	list.add("兮动人");
	list.add("xdr630");
	//1.void add(int index, Object ele):在index位置插入ele元素
	//在index = 1的位置插入一个对象
	list.add(1, "云兮动人");
	System.out.println("list=" + list);

在这里插入图片描述

  1. boolean addAll(int index,Collection eles):从index位置开始将eles中的所有元素添加进来
	List list = new ArrayList();
	list.add("兮动人");
	list.add("xdr630");
	//1.void add(int index, Object ele):在index位置插入ele元素
	//在index = 1的位置插入一个对象
	list.add(1, "云兮动人");
	System.out.println("list=" + list);
	//2.boolean addAll(int index,Collection eles):从index位置开始将eles中的所有元素添加进来
	List list2 = new ArrayList();
	list2.add("jack");
	list2.add("lucy");
	list.addAll(1, list2);
	System.out.println("list=" + list);

在这里插入图片描述

  1. Object get(int index):获取指定index位置的元素
	List list = new ArrayList();
	list.add("兮动人");
	list.add("xdr630");
	//1.void add(int index, Object ele):在index位置插入ele元素
	//在index = 1的位置插入一个对象
	list.add(1, "云兮动人");
	System.out.println("list=" + list);
	//2.boolean addAll(int index,Collection eles):从index位置开始将eles中的所有元素添加进来
	List list2 = new ArrayList();
	list2.add("jack");
	list2.add("lucy");
	list.addAll(1, list2);
	System.out.println("list=" + list);
	//3.Object get(int index):获取指定index位置的元素
	System.out.println(list.get(1));

在这里插入图片描述

  1. int indexOf(Object obj):返回obj在集合中首次出现的位置
	List list = new ArrayList();
	list.add("兮动人");
	list.add("xdr630");
	//1.void add(int index, Object ele):在index位置插入ele元素
	//在index = 1的位置插入一个对象
	list.add(1, "云兮动人");
	System.out.println("list=" + list);
	//2.boolean addAll(int index,Collection eles):从index位置开始将eles中的所有元素添加进来
	List list2 = new ArrayList();
	list2.add("jack");
	list2.add("lucy");
	list.addAll(1, list2);
	System.out.println("list=" + list);
	//3.Object get(int index):获取指定index位置的元素
	System.out.println(list.get(1));
	System.out.println(list.indexOf("jack"));
	//4.int indexOf(Object obj):返回obj在集合中首次出现的位置
	list.add("lucy");
	System.out.println("list=" + list);
	System.out.println(list.indexOf("lucy"));

在这里插入图片描述

  1. int lastlndexOf(Object obj):返回obj在当前集合中末次出现的位置
	List list = new ArrayList();
	list.add("兮动人");
	list.add("xdr630");
	//1.void add(int index, Object ele):在index位置插入ele元素
	//在index = 1的位置插入一个对象
	list.add(1, "云兮动人");
	System.out.println("list=" + list);
	//2.boolean addAll(int index,Collection eles):从index位置开始将eles中的所有元素添加进来
	List list2 = new ArrayList();
	list2.add("jack");
	list2.add("lucy");
	list.addAll(1, list2);
	System.out.println("list=" + list);
	//3.Object get(int index):获取指定index位置的元素
	System.out.println(list.get(1));
	System.out.println(list.indexOf("jack"));
	//4.int indexOf(Object obj):返回obj在集合中首次出现的位置
	list.add("lucy");
	System.out.println("list=" + list);
	System.out.println(list.indexOf("lucy"));
	//5.int lastlndexOf(Object obj):返回obj在当前集合中末次出现的位置
	list.add("兮动人");
	System.out.println("list=" + list);
	System.out.println(list.lastIndexOf("兮动人"));

在这里插入图片描述

  1. Object remove(int index):移除指定index位置的元素,并返回此元素
	List list = new ArrayList();
	list.add("兮动人");
	list.add("xdr630");
	//1.void add(int index, Object ele):在index位置插入ele元素
	//在index = 1的位置插入一个对象
	list.add(1, "云兮动人");
	System.out.println("list=" + list);
	//2.boolean addAll(int index,Collection eles):从index位置开始将eles中的所有元素添加进来
	List list2 = new ArrayList();
	list2.add("jack");
	list2.add("lucy");
	list.addAll(1, list2);
	System.out.println("list=" + list);
	//3.Object get(int index):获取指定index位置的元素
	System.out.println(list.get(1));
	System.out.println(list.indexOf("jack"));
	//4.int indexOf(Object obj):返回obj在集合中首次出现的位置
	list.add("lucy");
	System.out.println("list=" + list);
	System.out.println(list.indexOf("lucy"));
	//5.int lastlndexOf(Object obj):返回obj在当前集合中末次出现的位置
	list.add("兮动人");
	System.out.println("list=" + list);
	System.out.println(list.lastIndexOf("兮动人"));
	//6.Object remove(int index):移除指定index位置的元素,并返回此元素
	list.remove(0);
	System.out.println("list=" + list);

在这里插入图片描述

  1. Object set(int index, Object ele):设置指定index位置的元素为ele,相当于是替换.
	List list = new ArrayList();
	list.add("兮动人");
	list.add("xdr630");
	//1.void add(int index, Object ele):在index位置插入ele元素
	//在index = 1的位置插入一个对象
	list.add(1, "云兮动人");
	System.out.println("list=" + list);
	//2.boolean addAll(int index,Collection eles):从index位置开始将eles中的所有元素添加进来
	List list2 = new ArrayList();
	list2.add("jack");
	list2.add("lucy");
	list.addAll(1, list2);
	System.out.println("list=" + list);
	//3.Object get(int index):获取指定index位置的元素
	System.out.println(list.get(1));
	System.out.println(list.indexOf("jack"));
	//4.int indexOf(Object obj):返回obj在集合中首次出现的位置
	list.add("lucy");
	System.out.println("list=" + list);
	System.out.println(list.indexOf("lucy"));
	//5.int lastlndexOf(Object obj):返回obj在当前集合中末次出现的位置
	list.add("兮动人");
	System.out.println("list=" + list);
	System.out.println(list.lastIndexOf("兮动人"));
	//6.Object remove(int index):移除指定index位置的元素,并返回此元素
	list.remove(0);
	System.out.println("list=" + list);
	//7.Object set(int index, Object ele):设置指定index位置的元素为ele,相当于是替换.
	list.set(1, "杰西卡");
	System.out.println("list=" + list);

在这里插入图片描述

  1. List subList(int fromlndex, int tolndex):返回从fromIndex到tolndex位置的子集合
    注意:返回的子集合是一个 前闭后开 的区间 [a , b) , formIndex <= subList < toIndex
	List list = new ArrayList();
	list.add("兮动人");
	list.add("xdr630");
	//1.void add(int index, Object ele):在index位置插入ele元素
	//在index = 1的位置插入一个对象
	list.add(1, "云兮动人");
	System.out.println("list=" + list);
	//2.boolean addAll(int index,Collection eles):从index位置开始将eles中的所有元素添加进来
	List list2 = new ArrayList();
	list2.add("jack");
	list2.add("lucy");
	list.addAll(1, list2);
	System.out.println("list=" + list);
	//3.Object get(int index):获取指定index位置的元素
	System.out.println(list.get(1));
	System.out.println(list.indexOf("jack"));
	//4.int indexOf(Object obj):返回obj在集合中首次出现的位置
	list.add("lucy");
	System.out.println("list=" + list);
	System.out.println(list.indexOf("lucy"));
	//5.int lastlndexOf(Object obj):返回obj在当前集合中末次出现的位置
	list.add("兮动人");
	System.out.println("list=" + list);
	System.out.println(list.lastIndexOf("兮动人"));
	//6.Object remove(int index):移除指定index位置的元素,并返回此元素
	list.remove(0);
	System.out.println("list=" + list);
	//7.Object set(int index, Object ele):设置指定index位置的元素为ele,相当于是替换.
	list.set(1, "杰西卡");
	System.out.println("list=" + list);
	//8.List subList(int fromlndex, int tolndex):返回从fromIndex到tolndex位置的子集合
	//返回的子集合是一个 前闭后开 的区间,[a , b)  formIndex <= subList < toIndex
	List returnList = list.subList(0, 2);
	System.out.println(returnList);

在这里插入图片描述

3. 练习

  • 添加10个以上的元素((比如String “hello”),在2号位插入一个元素"xdr",获得第5个元素,删除第6个元素,修改第7个元素,在使用迭代器遍历集合,要求:使用List的实现类ArrayList完成。
	List list = new ArrayList();
	for (int i = 0; i < 12; i++) {
	    list.add("hello" + i);
	}
	System.out.println("list=" + list);
	//在2号位插入一个元素"xdr"
	list.add(1, "兮动人");
	System.out.println("list=" + list);
	//获得第5个元素
	System.out.println("第五个元素=" + list.get(4));
	//删除第6个元素
	list.remove(5);
	System.out.println("list=" + list);
	//修改第7个元素
	list.set(6, "lucy");
	System.out.println("list=" + list);
	//使用迭代器遍历集合
	Iterator iterator = list.iterator();
	while (iterator.hasNext()) {
	    Object obj =  iterator.next();
	    System.out.println("obj=" + obj);
	}

在这里插入图片描述

4. List 的三种遍历方式 [ArrayList, LinkedList,Vector]

	//List 接口的实现子类还有 Vector LinkedList ,实现效果都是一样的
	//List list = new LinkedList();
	//List list = new Vector();
	List list = new ArrayList();
	list.add("xdr");
	list.add("兮动人");
	list.add("jack");
	list.add("lucy");
	
	//遍历
	System.out.println("====迭代器====");
	//1.迭代器
	Iterator iterator = list.iterator();
	
	while (iterator.hasNext()) {
	    Object obj =  iterator.next();
	    System.out.println(obj);
	}
	
	System.out.println("====增强for====");
	//2.增强 for
	for (Object o : list) {
	    System.out.println(o);
	}
	System.out.println("====普通for====");
	//3.普通for循环
	for (int i = 0; i < list.size(); i++) {
	    System.out.println(list.get(i));
	}

在这里插入图片描述

5. 实现类的练习

  • 使用List的实现类添加三本图书,并遍历,打印如下效果
名称:xx		价格:xx		作者:xx
名称:xx		价格:xx		作者:xx
名称:xx		价格:xx		作者:xx
  1. 按价格排序从低到高(使用冒泡法)
  2. 要求使用ArrayList、LinkedList 和Vector 三种集合实现
public class Book {
    private String name;
    private String author;
    private double price;

    public Book(String name, String author, double price) {
        this.name = name;
        this.author = author;
        this.price = price;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getAuthor() {
        return author;
    }

    public void setAuthor(String author) {
        this.author = author;
    }

    public double getPrice() {
        return price;
    }

    public void setPrice(double price) {
        this.price = price;
    }

    @Override
    public String toString() {
        return "名称:" + name + "\t\t作者:" + author + "\t\t价格:" + price;
    }
}
public class ListExercise02 {
    public static void main(String[] args) {
        //List list = new LinkedList();
        //List list = new Vector();
        List list = new ArrayList();

        list.add(new Book("西游记", "吴承恩", 100));
        list.add(new Book("红楼梦", "曹雪芹", 70));
        list.add(new Book("水浒传", "施耐庵", 80));
        list.add(new Book("三国演义", "罗贯中", 90));

        //遍历
        for (Object o : list) {
            System.out.println(o);
        }

        //冒泡排序
        sort(list);

        System.out.println("===排序后===");
        for (Object o : list) {
            System.out.println(o);
        }

    }
    //静态方法
    //价格是从小到大
    public static void sort(List list) {

        int listSize = list.size();
        for (int i = 0; i < listSize - 1; i++) {
            for (int j = 0; j < listSize - 1 - i; j++) {
                //取出对象 Book
                Book book1 = (Book) list.get(j);
                Book book2 = (Book) list.get(j + 1);
                if (book1.getPrice() > book2.getPrice()) {//交换
                    list.set(j, book2);
                    list.set(j + 1, book1);
                }
            }
        }
    }
}

在这里插入图片描述

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-11-30 15:52:09  更:2021-11-30 15:52:13 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 13:27:19-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码