当前位置: 首页 > news >正文

【数据结构与算法】ArrayList与顺序表(上)

🍗🍗hello,进来的小伙伴们,你们好呐!

🍔🍔系列专栏:【数据结构与算法】

🍼🍼作者简介:一名大三在读的科班Java小白,星夜漫长,你我同行!

🌯🌯本篇内容:初始ArrayList与顺序表,简单了解ArrayList的基本用法,入门顺序表!

🍤🍤给大家推荐一个超级好用的刷题网站——牛客网

点击链接注册,开启刷题之路!

c0a3bbd800fb4e5aa80e3a387596bcc2.png

 一、线性表

🍊线性表(linear list)是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列...
🍅线性表在逻辑上是线性结构,也就说是连续的一条直线。但是在物理结构上并不一定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储。

56f4bfe4cece4c4f864459be0c316057.png

 

 二、ArrayList简介

1.集合框架图

9447d266173b4713b3a464d2dd7c937f.png

🍜🍜我们可以发现,List是个接口,并不能直接用来实例化。
如果要使用,必须去实例化List的实现类。在集合框架中,ArrayList和LinkedList都实现了List接口,本篇我们主要介绍的是ArrayList。

🍚🍚结论:

1. ArrayList实现了RandomAccess接口,表明ArrayList支持随机访问。
2. ArrayList实现了Cloneable接口,表明ArrayList是可以clone的。
3. ArrayList实现了Serializable接口,表明ArrayList是支持序列化的。
4. 和Vector不同,ArrayList不是线程安全的,在单线程下可以使用,在多线程中可以选择Vector或者CopyOnWriteArrayList。
5. ArrayList底层是一段连续的空间,并且可以动态扩容,是一个动态类型的顺序表。

 三、ArrayList使用

1、ArrayList三种方式构造

public class demo3 {
    public static void main(String[] args) {
        // 构造一个空的列表
        //当我们调用不带参数的构造方法的时候,只有第一次add的时候 才会分配大小为10的内存
        ArrayList<String> s1 = new ArrayList<>();
        s1.add("hello");
        s1.add("java");
        System.out.println(s1);


        //构造一个具有3个容量的顺序表
        ArrayList<Integer> n1 = new ArrayList<>(3);
        n1.add(666);
        n1.add(888);
        n1.add(999);
        System.out.println(n1);


        //ArrayList(Collection<? extends E> c) 大类实现Collection接口便可以传
        ArrayList<Integer> n2 = new ArrayList<>(n1);//把n1里面的元素放到n2里面
        System.out.println(n2);
    }
}

运行结果: b81f1dfaaf8c4cb8aabad6e1ece6e3db.png

 2、ArrayList的常见操作

ArrayList的操作方法还是蛮多的,这里我提供几个比较常用的使用方法,如果大家还想了解更多的操作方法可以在参考文档查找!

在线文档:

2eed5f293158432b89fa9d0aacc05003.png

 常用方法:

7f27689d431e4d498c27e8b6a72e30e5.png

在线演示:

public class demo5 {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("hello java");
        list.add("BATJ");
        list.add("大厂!!!");
        System.out.println(list);
        
        // 获取list中有效元素个数
        System.out.println(list.size());
        
        // 获取和设置index位置上的元素,注意index必须介于[0, size)间
        System.out.println(list.get(1));
        list.set(1, "好好学习!!!");
        System.out.println(list.get(1));
        
        // 在list的index位置插入指定元素,index及后续的元素统一往后搬移一个位置
        list.add(1, "学好数据结构!");
        System.out.println(list);
        
        // 删除指定元素,找到了就删除,该元素之后的元素统一往前搬移一个位置
        list.remove("BATJ");
        System.out.println(list);
        
        
        // 删除list中index位置上的元素,注意index不要超过list中有效元素个数,否则会抛出下标越界异常
        list.remove(list.size()-1);
        System.out.println(list);
        
        // 检测list中是否包含指定元素,包含返回true,否则返回false
        if(list.contains("学好数据结构!")){
        list.add("学好算法!");
        }
        
        // 使用list中[0, 4)之间的元素构成一个新的ArrayList返回
        List<String> ret = list.subList(0, 4);
        System.out.println(ret);
        
    }
}

运行结果:

6b11dfae352248c580ae98660abbe231.png

 加上clear()方法后,我们在看运行结果:

03abf2323850493a958407b0cdc77e7c.png

 运行结果:

ae3b1ff394d94496a064e936d2eb34d2.png

3、 ArrayList的遍历

ArrayList 可以使用三方方式遍历:for循环+下标、foreach、使用迭代器。

public class Bianli {
    public static void main(String[] args) {
        ArrayList<Integer> c1 = new ArrayList<>();
        c1.add(1);
        c1.add(2);
        c1.add(3);
        c1.add(4);
        c1.add(5);
        for (int i = 0; i < c1.size(); i++) {//使用下标for遍历
            System.out.print(c1.get(i)+" ");
        }
        System.out.println();


        for (Integer s1:c1) {//使用foreach遍历
            System.out.print(s1+" ");
        }
        System.out.println();


        Iterator<Integer> it = c1.iterator();//使用迭代器遍历
        while (it.hasNext()){
            System.out.print(it.next()+" ");
        }
        System.out.println();
    }
}

运行结果:

407989fcdbf64fa3a21c6928810ad96a.png

相关文章:

  • 【前端进阶】-TypeScript类型声明文件详解及使用说明
  • [Spring boot] Spring boot 实现发送邮件功能
  • 万字指针超详细总结
  • 列表页常见 hook 封装
  • 集合_HashSet(HashMap)扩容机制源码简析
  • Spring注解@Qualifier的详细用法你知道几种「扩展点实战系列」- 第444篇
  • uni-app 微信小程序中关于 map 地图使用案例分享
  • 工业级成熟航运港口人工智能产品全球前三船公司及港口码头落地,中国上海人工智能独角兽中集飞瞳全球应用最广规模最大最先进港航AI企业
  • CSS基础篇---02选择器进阶、背景样式、显示模式
  • 【C语言】自定义类型 —— 结构体
  • 千万级用户ms级抽奖N名设计方案
  • 2022第五空间WEBMISC
  • 说几句得罪人的大实话
  • Spark 优化 (二) --------- Spark 数据倾斜
  • 第01篇:系统化学习, 搞定Spring容器管理
  • 深入了解以太坊
  • Akka系列(七):Actor持久化之Akka persistence
  • css系列之关于字体的事
  • java 多线程基础, 我觉得还是有必要看看的
  • JavaScript设计模式与开发实践系列之策略模式
  • SQLServer之创建数据库快照
  • 不上全站https的网站你们就等着被恶心死吧
  • 给第三方使用接口的 URL 签名实现
  • 基于游标的分页接口实现
  • 什么软件可以剪辑音乐?
  • 文本多行溢出显示...之最后一行不到行尾的解决
  • HanLP分词命名实体提取详解
  • 从如何停掉 Promise 链说起
  • ​渐进式Web应用PWA的未来
  • # 手柄编程_北通阿修罗3动手评:一款兼具功能、操控性的电竞手柄
  • #NOIP 2014# day.1 生活大爆炸版 石头剪刀布
  • #鸿蒙生态创新中心#揭幕仪式在深圳湾科技生态园举行
  • #中的引用型是什么意识_Java中四种引用有什么区别以及应用场景
  • (Forward) Music Player: From UI Proposal to Code
  • (NSDate) 时间 (time )比较
  • (转) ns2/nam与nam实现相关的文件
  • (转)visual stdio 书签功能介绍
  • ***php进行支付宝开发中return_url和notify_url的区别分析
  • .cn根服务器被攻击之后
  • .NET CF命令行调试器MDbg入门(三) 进程控制
  • .Net CF下精确的计时器
  • .net core webapi 部署iis_一键部署VS插件:让.NET开发者更幸福
  • .NET 编写一个可以异步等待循环中任何一个部分的 Awaiter
  • .net连接MySQL的方法
  • @Bean注解详解
  • @staticmethod和@classmethod的作用与区别
  • @Transient注解
  • [2023-年度总结]凡是过往,皆为序章
  • [AI]ChatGPT4 与 ChatGPT3.5 区别有多大
  • [Android Pro] Notification的使用
  • [Android View] 可绘制形状 (Shape Xml)
  • [BT]小迪安全2023学习笔记(第15天:PHP开发-登录验证)
  • [C++]C++类基本语法
  • [C++核心编程](四):类和对象——封装
  • [CareerCup] 17.8 Contiguous Sequence with Largest Sum 连续子序列之和最大