如何用Java实现一个顺序表
发表于:2025-11-12 作者:千家信息网编辑
千家信息网最后更新 2025年11月12日,本篇内容介绍了"如何用Java实现一个顺序表"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!实现一个顺
千家信息网最后更新 2025年11月12日如何用Java实现一个顺序表
本篇内容介绍了"如何用Java实现一个顺序表"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
实现一个顺序表
接口实现
定义一个MyArrayList类,在类中实现以下函数
public class MyArrayList { }数组的定义
public int[] elem;//定义一个整形数组 public int usize;//usize表示数组的长度 public MyArrayList(){ this.elem = new int[5];}打印顺序表
for循环打印顺序表的每一位
public void display(){ for (int i = 0; i < this.usize; i++) { System.out.print(this.elem[i]+" "); } System.out.println(); }在pos位置新增元素
先定义一个isFull函数判断顺序表是否满了,满了返回true,没满则返回false
public boolean isFull(){ if (this.usize == this.elem.length){ return true; } return false; }将pos位置后的元素后移,顺序表顺序表长度增加一位
public void add(int pos, int data){ //判断顺序表是否满了 if (isFull()){ System.out.println("顺序表已满"); //扩容 this.elem = Arrays.copyOf(this.elem,2*this.usize); } //判断pos的合法性 if (pos < 0 || pos > this.usize){ System.out.println("pos位置不合法"); return; } //将pos位置后的数字后移 for (int i = this.usize-1; i >= pos; i--) { this.elem[i+1] = this.elem[i]; } this.elem[pos] = data; this.usize++; }判定是否包含某个元素
public boolean contains(int key){ for (int i = 0; i < this.usize; i++) { if (this.elem[i] == key){ return true; } } return false; }查找某个对应元素的位置
返回它的位置
public int search(int key){ for (int i = 0; i < this.usize; i++) { if (this.elem[i] == key){ return i; } } return -1; }获取pos位置的元素
定义一个isEmpty函数判断顺序表是否为空
public boolean isEmpty(){ return this.usize == 0; }public int getPos(int pos){ //判断顺序表是否为空 if (isEmpty()){ return -1; } //判断pos 位置是否合法 if (pos < 0 || pos >= this.usize){ return -1; } return this.elem[pos]; }给pos位置的元素设为value 更新为新的数字
public void setPos(int pos,int value){ //判断顺序表是否为空 if (isEmpty()){ return; } //判断pos位置是否合法 if (pos < 0 || pos >= this.usize){ return; } this.elem[pos] = value; }删除第一次出现的关键字key
查找到关键字,从关键字所在的位置开始到顺序表结束每一项前移,覆盖掉关键字,长度减少一位
public void remove(int key){ int index= search(key); if (key == -1){ System.out.println("关键字不存在"); return; } for (int i = key; i < this.usize-1; i++) { this.elem[i] = this.elem[i+1]; } this.usize--; }获取顺序表长度
public int size(){ return this.usize; }清空顺序表
顺序表长度直接为0
public void clear(){ this.usize = 0; }实现这个顺序表
定义一个测试类,测试这些函数的输出
public class TestDemo { public static void main(String[] args) { MyArrayList myArrayList = new MyArrayList(); //给这个顺序表写入1,2,3,4,5 myArrayList.add(0,1); myArrayList.add(1,2); myArrayList.add(2,3); myArrayList.add(3,4); myArrayList.add(4,5); //打印这个顺序表 myArrayList.display(); //判定5这个元素是否在该顺序表中 System.out.println(myArrayList.contains(5)); //查找5这个元素 返回它的位置 System.out.println(myArrayList.search(5)); //获取3位置的元素 System.out.println(myArrayList.getPos(3)); //将4位置的元素重新赋值为9 myArrayList.setPos(4,9); //打印新的顺序表 myArrayList.display(); //删除第一次出现的元素4 myArrayList.remove(4); //打印新的顺序表 myArrayList.display(); //获取顺序表的长度 System.out.println(myArrayList.size()); System.out.println("清空"); //清空顺序表 myArrayList.clear(); //打印新的顺序表 myArrayList.display(); }}顺序表的优缺点
优点:顺序表查找方便,知道这个元素的位置就可以直接找到这个元素。
缺点:扩容一般成2倍增长,会有一定的空间浪费。
"如何用Java实现一个顺序表"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
顺序
位置
元素
长度
关键
关键字
函数
合法
数组
内容
数字
更多
知识
第一次
后移
测试
输出
实用
学有所成
接下来
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
天津优购软件开发
数据库vba代码大全
双线服务器网游
无期迷途获取服务器
计算机网络技术专业考研方向
流媒体转发存储服务器
csgo社区服务器下载暂停
我国网络安全法律颁布的先后顺序
广东品质网络技术开发经验丰富
交投集团网络安全岗位职责
软件开发典型企业动向
简易版数据库有什么不同
网络技术员岗位职责范本大全
东方导航软件开发
义乌嵌入式软件开发教程
联想服务器管理口怎么设置
公安的大数据库
Java数据库防篡改技术
亚信有数据库审计系统吗
网络技术学院奖获奖
管理员目前有三台服务器
网络安全调查与研究
麻将管理服务器客户端是什么意思
开发者怎么创建服务器
网络安全与运维区别
国家网络安全英文怎么说
昆山软件开发工程师
软件开发和军工方向哪个好
服务器硬盘多少转速
人渣被该服务器移除