集合框架,List常用API,栈和队列初识

ops/2024/10/11 13:19:07/

回顾

集合框架

在这里插入图片描述

两个重点——ArrayList和HashSet.

在这里插入图片描述

Vector/ArraysList/LinkedList区别

VectorArraysListLinkedList
底层实现数组数组链表
线程安全安全不安全不安全
增删效率较低较低
扩容*2*1.5--------

在这里插入图片描述

(>>)运算级最低,记得加括号。

常用Api

List*

remove()的两种删除

在这里插入图片描述

API解释
1add()添加
2remove(index)索引删除
3remove(Object)对象删除
4set(index,e)《Set》修改
5clear()清空
6size()长度
7get(index)《List》查询
8indexOf()《List》找出位置
9contains(用前要重写)包含
10isEmpty()集合为空
11itreator()迭代器(遍历和删除)
12toString()转换为字符串

数组比较

在这里插入图片描述
在这里插入图片描述

Stack栈

后进先出

栈是一种特殊的数据结构,后进先出。
在这里插入图片描述

结构

底层还是数组。Vector派生出来的,继承Vector。

在这里插入图片描述

Api方法

在这里插入图片描述

push():入栈

在这里插入图片描述

peek():栈顶

取栈顶不会删除栈顶。

System.out.println(“栈顶:”+stack.peek());//栈顶——最后进栈的

pop():出栈

出栈会删除栈顶元素。

System.out.println(“wu:”+stack.pop());//出栈

在这里插入图片描述

完整代码:

package com.ffyc.Stack;import java.util.Stack;public class StackDemo01 {public static void main(String[] args) {Stack<Integer> stack = new Stack<>();//存——压栈stack.push(1);stack.push(2);stack.push(3);stack.push(4);stack.push(5);System.out.println("栈:"+stack);System.out.println("栈顶:"+stack.peek());//栈顶——最后进栈的//System.out.println("wu:"+stack.pop());//出栈//倒序打印while (stack.size()>0){int temp = stack.pop();//pop()后当前的栈顶元素自动删除System.out.println(temp);}}
}

反转"hello"

在这里插入图片描述

中间的回文数量的题可以用

计算器题目

准备工作

在这里插入图片描述

length-1 否则越界

在这里插入图片描述

————————————————————————————————————————————

在这里插入图片描述

Queue队列

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

offer()进

队头添加数据

poll()出

从队头取出元素/数据

peek()顶

取出最先进队的元素。第一个offer()进去的元素。

在这里插入图片描述
是下面代码的输出:queue.peek—>1

队列

在这里插入图片描述

可排序的队列

在这里插入图片描述


http://www.ppmy.cn/ops/105483.html

相关文章

编译 ffmpeg 以支持AVS格式视频解码与解码

前言 当前文章介绍如何在Linux下使用FFmpeg转码其他视频格式到AVS格式的指南&#xff0c;包括编译FFmpeg以支持XAVS编码和如何使用FFmpeg进行转码。 AVS (Audio Video Coding Standard) 格式是一种由中国主导制定的视频编码标准&#xff0c;全称为“中国数字音视频编解码技术…

StyleGAN——生成风格化的视频内容,特别是在艺术视频或动画领域,可以将视频的视觉风格转换为特定的艺术风格

一、StyleGAN介绍 StyleGAN 是由 NVIDIA 研究团队开发的一种生成对抗网络&#xff08;GAN&#xff09;模型&#xff0c;专门用于生成高质量的图像。与传统的 GAN 不同&#xff0c;StyleGAN 引入了风格控制机制&#xff0c;可以通过改变生成过程中的特定特征来生成多样化的图像…

django学习入门系列之第十点《django中数据库操作--创建与删除表》

文章目录 django创建与删除表开始创建表创建指令新增表删除表删除列新增列修改报错提示语言总结 往期回顾 django创建与删除表 删除表 创建表 修改表 操作目录 开始创建表 class text_into(models.Model):name models.CharField(max_length32)password models.CharField…

Redis Zset 类型:Score 属性在数据排序中的作用

Zset 有序集合 一 . zset 的引入二 . 常见命令2.1 zadd、zrange2.2 zcard2.3 zcount2.4 zrevrange、zrangebyscore2.5 zpopmax、zpopmin2.6 bzpopmax、bzpopmin2.7 zrank、zrevrank2.8 zscore2.9 zrem、zremrangebyrank、zremrangebyscore2.10 zincrby2.11 集合间操作交集 : zi…

Python大数据之Hadoop学习——day06_hive内外部表

一.hive内外表操作 1. 建表语法 create [external] table [if not exists] 表名(字段名 字段类型 ,字段名 字段类型,...) [partitioned by (分区字段名 分区字段类型)] # 分区表固定格式 [clustered by (分桶字段名) into 桶个数 buckets] # 分桶表固定格式 [so…

使用VM创建centos7环境

目录 1、安装VMware Workstation1.1安装VMware Workstation pro 161.2激活VMware Workstation pro 16 2. 创建centos7虚拟机2.1 点击创建新的虚拟机2.2 配置iso镜像2.3开启虚拟机&#xff0c;安装centos7系统 3. 配置网络方法1&#xff1a;方法2&#xff1a;配置静态IP地址 4. …

Unity 不规则进度条显示根据点对点进行

using UniRx; using UnityEngine; using UnityEngine.UI; public class SpeedVehicle : MonoBehaviour { //加速踏板 [SerializeField] private Image AcceleratorApertureSlider; //制动踏板 [SerializeField] private Image BrakingPedalApertureSlider; private static re…

如何打造中小学在线教学平台?Java SpringBoot集成Vue,教育资源管理新篇章

✍✍计算机编程指导师 ⭐⭐个人介绍&#xff1a;自己非常喜欢研究技术问题&#xff01;专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目&#xff1a;有源码或者技术上的问题欢迎在评论区一起讨论交流&#xff01; ⚡⚡ Java实战 |…