ArrayList与顺序表

文章目录

  • 一. 顺序表是什么
  • 二. ArrayList是什么
  • 三. ArrayList的构造方法
  • 四. ArrayList的常见方法
    • 4.1 add()
    • 4.2 size()
    • 4.3 remove()
    • 4.4 get()
    • 4.5 set()
    • 4.6 contains()
    • 4.7 lastIndexOf()和 indexOf()
    • 4.8 subList()
    • 4.9 clear()
  • 以上就是ArrayList的常见方法!!

一. 顺序表是什么

顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。

二. ArrayList是什么

在这里插入图片描述

在集合框架中,ArrayList是一个普通的类,实现了List接口,它有以下几个特点:

  • ArrayList底层是一段连续的空间,并且可以动态扩容,是一个动态类型的顺序表。
  • ArrayList支持随机访问,但其插入和删除效率低。
  • ArrayList是可以clone的,是支持序列化的。
  • ArrayList不是线程安全的,在单线程下可以使用,在多线程中可以选择Vector或者CopyOnWriteArrayList。

三. ArrayList的构造方法

ArrayList提供了以下三种构造方法

方法一:也是最推荐的方法
在这里插入图片描述

// 构造一个空的列表
List<Integer> list = new ArrayList<>();

方法二:
在这里插入图片描述

// 构造一个具有10个容量的列表
List<Integer> list = new ArrayList<>(10);

方法三:
在这里插入图片描述

List<Integer> list = new ArrayList<>(10);
List<Integer> list2 = new ArrayList<>(list);

重点
对顺序表进行初始化的时候,一定要指定元素的类型,否则,任意类型的元素都可以存放,会造成严重后果。

四. ArrayList的常见方法

4.1 add()

在这里插入图片描述

public static void main(String[] args) {List<Integer> list=new ArrayList<>(); //此处的add():将元素尾插进ArrayList中list.add(1);list.add(2);System.out.println(list);//此处的add():在list的index位置插入指定元素,index及后续的元素统一往后搬移一个位置list.add(1,10);System.out.println(list);}

在这里插入图片描述

4.2 size()

获取list中有效元素个数

 public static void main(String[] args) {List<Integer> list=new ArrayList<>();list.add(1);list.add(2);System.out.println(list);// 获取list中有效元素个数System.out.println(list.size());}

4.3 remove()

在这里插入图片描述

 public static void main(String[] args) {List<String> list=new ArrayList<>();list.add("苹果");list.add("香蕉");System.out.println(list);// 删除指定元素,找到了就删除,该元素之后的元素统一往前搬移一个位置,这里没有找到list.remove("梨");System.out.println(list);//删除list中index位置上的元素,这里要注意 index 是否有效list.remove(1);System.out.println(list);}

在这里插入图片描述

4.4 get()

在这里插入图片描述

public static void main(String[] args) {List<String> list=new ArrayList<>();list.add("苹果");list.add("香蕉");//获取index位置上的元素,注意index是否有效(index必须介于[0,size)间)System.out.println(list.get(0));}

在这里插入图片描述

4.5 set()

在这里插入图片描述

public static void main(String[] args) {List<String> list=new ArrayList<>();list.add("苹果");list.add("香蕉");//设置index位置上的元素为指定元素,注意index是否有效list.set(1,"梨");System.out.println(list.get(1));System.out.println(list);}

在这里插入图片描述

4.6 contains()

在这里插入图片描述

public static void main(String[] args) {List<String> list=new ArrayList<>();list.add("苹果");list.add("香蕉");//查看list中是否包含指定元素,包含返回true,否则返回falseif(list.contains("西瓜")){System.out.println("list中包含西瓜元素");}else{System.out.println("list中不包含西瓜元素");}}

在这里插入图片描述

4.7 lastIndexOf()和 indexOf()

在这里插入图片描述

public static void main(String[] args) {List<String> list=new ArrayList<>();list.add("苹果");list.add("香蕉");list.add("梨");list.add("苹果");// 查找指定元素第一次出现的位置:indexOf从前往后找,lastIndexOf从后往前找System.out.println(list.indexOf("苹果"));System.out.println(list.lastIndexOf("苹果"));}

在这里插入图片描述

4.8 subList()

在这里插入图片描述

public static void main(String[] args) {List<String> list=new ArrayList<>();list.add("苹果");list.add("香蕉");list.add("梨");list.add("苹果");// 截取list中[0, 2)之间的元素构成一个新的ArrayList返回List<String> list2=list.subList(0,2);System.out.println(list2);}

在这里插入图片描述

4.9 clear()

清空ArrayList中的元素。

以上就是ArrayList的常见方法!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/59482.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RHCE——九、SELinux

SELinux 一、概念1、作用2、SELinux与传统的权限区别 二、SELinux工作原理1、名词解释主体&#xff08;Subject&#xff09;目标&#xff08;Object&#xff09;策略&#xff08;Policy&#xff09;安全上下文&#xff08;Security Context&#xff09; 2、文件安全上下文查看1…

element——switch接口成功后赋值打开开关

应用场景 基本用法使用v-model双向绑定值&#xff0c;进行开关控制 例子1:需求&#xff1a; **点击switch&#xff0c;出弹窗&#xff0c;点击弹窗保存按钮调接口成功后再赋值&#xff08;row.orderButtonValue“1”&#xff09;打开switch开的状态变颜色。 在vue 中使用 :va…

安全开发-JS应用NodeJS指南原型链污染Express框架功能实现审计WebPack打包器第三方库JQuery安装使用安全检测

文章内容 环境搭建-NodeJS-解析安装&库安装安全问题-NodeJS-注入&RCE&原型链案例分析-NodeJS-CTF题目&源码审计打包器-WebPack-使用&安全第三方库-JQuery-使用&安全 环境搭建-NodeJS-解析安装&库安装 Node.js是运行在服务端的JavaScript 文档参考…

分布式事务篇-2.4 Spring-Boot整合Seata

文章目录 前言一、pom jar导入:二、项目配置&#xff1a;2.1 配置 说明&#xff1a;2.1 .1 seata server 端:2.1 .2 seata client 端: 2.2 开启seata 对于数据源的代理:2.3 seata-client 的注册中心&#xff1a;2.4 seata-client 的配置中心&#xff1a;2.5 去掉手写的数据源代…

【第四阶段】kotlin语言的mutator函数学习

1.mutator特性1&#xff1a;使用list可以直接 - fun main() {val list mutableListOf(123,456,789)//特性1 可是直接使用list -list 111list-123println(list) }执行结果 2.mutator特性2&#xff1a;removeIF() 如果实现是true 会自动遍历整个集合&#xff0c;一个一个的移除…

新亮点!安防视频监控/视频集中存储/云存储平台EasyCVR平台六分屏功能展示

安防视频监控/视频集中存储/云存储/磁盘阵列EasyCVR平台可拓展性强、视频能力灵活、部署轻快&#xff0c;可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等&#xff0c;以及支持厂家私有协议与SDK接入&#xff0c;包括海康Ehome、海大宇等设备的SDK等。平台既具备传统安…

【Robot Framework】发送GET和POST请求

做接口自动化时&#xff0c;经常要使用GET与POST请求&#xff0c;那么如何使用RF发送对应的请求呢&#xff1f; 一、安装RequestsLibrary pip install robotframework-requests安装以后&#xff0c;导入到对应的测试套件或测试用例中. 本次主要介绍通过RequestsLibrary来实现…

【状压+概率DP】CF678 E

Problem - E - Codeforces 题意&#xff1a; 思路&#xff1a; 首先&#xff0c;n < 18&#xff0c;应当想到状压 很明显&#xff0c;这里可以使用状压DP 设 dp[s][i] 表示&#xff0c;现在选的方案为 s &#xff0c;且我是 i 的最终胜利的概率是多少 重要的是转移 这是…

数学建模——校园供水系统智能管理

import pandas as pd data1pd.read_excel("C://Users//JJH//Desktop//E//附件_一季度.xlsx") data2pd.read_excel("C://Users//JJH//Desktop//E//附件_二季度.xlsx") data3pd.read_excel("C://Users//JJH//Desktop//E//附件_三季度.xlsx") data4…

飞天使-python的模块与包与装饰器

文章目录 模块与包标准模块第三方模块自定义模块 高级语法切片迭代器/生成器高级模式&#xff08;闭包&#xff09;高级模式&#xff08;装饰器&#xff09; 参考视频 模块与包 标准模块 import os print(os.getcwd())import sys print(sys.argv) print(sys.platform) print(…

ETC reset

ETC重新激活 换前挡风玻璃膜会把ETC设备拿下来&#xff0c;需要到【ETC服务中心】重新【粘上去】&#xff0c;另外需要工作人员用手持终端【重新激活】 ETC 背面有个 【白色】开关小柱子&#xff0c;一旦拆下来就失效&#xff0c;因为这个开关弹出来了 截面图看就是这样的&…

万人在线,一站式自动化运维 SysOM 3.0重磅发布!龙蜥社区系统运维 MeetUp 回顾来了

8 月 12 日&#xff0c;由龙蜥社区系统运维 SIG 主办&#xff0c;乘云数字协办的&#xff0c;主题为“观测&#xff0c;让运维更简单&#xff01;”的系统运维 MeetUp 于杭州圆满结束。来自乘云数字、谐云科技、乐维、云杉网络、擎创科技、观测云、阿里云以及浙江大学等众多厂商…

Linux 多线程同步机制(上)

文章目录 前言一、线程同步二、互斥量 mutex三、死锁总结 前言 一、线程同步 在多线程环境下&#xff0c;多个线程可以并发地执行&#xff0c;访问共享资源&#xff08;如内存变量、文件、网络连接 等&#xff09;。 这可能导致 数据不一致性, 死锁, 竞争条件等 问题。 为了解…

医院常见的HIS、CIS、LIS、EMR、PACS、RIS医疗信息化中的介绍

医院常见的HIS、CIS、LIS、EMR、PACS、RIS分别是&#xff1a; HIS&#xff08;Hospital Information System&#xff09;&#xff1a;医院信息系统&#xff0c;是医院管理信息化的核心系统&#xff0c;包括病人管理、医生管理、药品管理、医疗设备管理、财务管理等多个方面&am…

Unity插件---Dotween

1.什么是DOTween DoTween 是由 Demigiant 开发的&#xff0c;被广泛应用于 Unity 游戏开发中。它是一个流行的动画插件&#xff0c;被许多开发者用于创建流畅、高效的动画效果&#xff0c;提升游戏体验。 2.DOTween的初始配置 ①set up 首先找到DOTween Unity Panel 的面板 点…

c# 本地化中英文切换

区域 线程默认区域为当前计算机所选区域 设置当前区域&#xff1a; Thread.CurrentThread.CurrentCulture new CultureInfo(“zh-cn”); 获取当前区域&#xff1a; Console.WriteLine(Thread.CurrentThread.CurrentCulture.ToString()); 区域名称&#xff1a; “zh-cn” 中文…

数据结构(Java实现)-栈和队列

栈&#xff1a;一种特殊的线性表&#xff0c;其只允许在固定的一端进行插入和删除元素操作。 先进后出 栈的使用 栈的模拟实现 上述的主要代码 public class MyStack {private int[] elem;private int usedSize;public MyStack() {this.elem new int[5];}Overridepublic …

【数学建模竞赛】各类题型及解题方案

评价类赛题建模流程及总结 建模步骤 建立评价指标->评价体系->同向化处理&#xff08;都越多越好或越少越少&#xff09;->指标无量纲处理 ->权重-> 主客观->合成 主客观评价问题的区别 主客观概念主要是在指标定权时来划分的。主观评价与客观评价的区别…

Django实现音乐网站 ⒁

使用Python Django框架制作一个音乐网站&#xff0c; 本篇主要是歌手页-全部歌手页功能开发。 目录 分出首页样式内容 创建首页样式文件 首页引入样式文件 全部歌手列表 创建路由 显示视图 引入分页实现库 视图方法 创建歌手首页 增加歌手跳转 导航条改活 首页增加…

STM32H750+LAN8720无操作系统移植lwip

前言 本文提供移植好的工程&#xff0c;见本文绑定资源 环境 STM32CubeMX&#xff1a; V6.8.1 STM32H7 HAL Pack&#xff1a; V1.11.1 硬件连接 STM32H750 GPIO定义如下&#xff1a; LAN8720 GPIO定义如下&#xff1a; 连接方式如下&#xff1a; LAN8720       <—…