iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Java实现一个顺序表的完整代码
  • 853
分享到

Java实现一个顺序表的完整代码

2024-04-02 19:04:59 853人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

实现一个顺序表 接口实现 定义一个MyArrayList类,在类中实现以下函数 public class MyArrayList { } 数组的定义 public

实现一个顺序表

接口实现

定义一个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倍增长,会有一定的空间浪费。

--结束END--

本文标题: Java实现一个顺序表的完整代码

本文链接: https://www.lsjlt.com/news/123597.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java实现一个顺序表的完整代码
    实现一个顺序表 接口实现 定义一个MyArrayList类,在类中实现以下函数 public class MyArrayList { } 数组的定义 public ...
    99+
    2024-04-02
  • Java如何实现一个顺序表
    这篇文章主要介绍Java如何实现一个顺序表,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!实现一个顺序表接口实现定义一个MyArrayList类,在类中实现以下函数public class MyAr...
    99+
    2023-06-14
  • Java完整实现记事本代码
    进入今天的正题: 1.整体设计思路如下: (1)使用顶层容器JFrame。 (2)设置功能菜单并通过BorderLayout进行边框布局管理。 (3)设置相应按钮与文件编辑区。 (4...
    99+
    2024-04-02
  • 冒泡排序(Java)(完整代码)
       推荐我平时练习代码的工具,不用打开eclipse或者idea那么麻烦。 菜鸟工具 冒泡排序无非就是俩个for循环。 内嵌的for是用来求出当前数组最大或最小的那个元素 第一for是用来循环查找次最大的元素直到全部排序好。 先静态化创...
    99+
    2023-09-25
    算法 排序算法 数据结构
  • Java实现生成Excel树形表头完整代码示例
    本文主要分享了Java实现生成Excel树形表头完整代码示例,没有什么好解释的,直接看看代码过程。源数据格式:String[] targetNames = { "指标名称", "单位", ...
    99+
    2023-05-30
    java excel表头 ava
  • 用c语言实现一个电话薄(附完整代码)
    先看一下这个小程序的效果 这里我为了演示方便,把人数固定为3个; 人数都是可以自定义的; 下面是这个简单的代码: #include<stdio.h> typedef s...
    99+
    2024-04-02
  • Java实现顺序表的操作
    本文实例为大家分享了Java实现顺序表的基本操作,供大家参考,具体内容如下 静态顺序表:使用定长数组存储。动态顺序表:使用动态开辟的数组存储。 接口 package com.gith...
    99+
    2024-04-02
  • C/C++实现线性顺序表的示例代码
    目录线性顺序表简介C语言实现代码C++语言实现代码线性顺序表简介 使用顺序存储结构的线性存储结构的表为线性顺序表,线性存储结构是元素逻辑结构一对一,顺序存储结构是元素物理结构连续,线...
    99+
    2024-04-02
  • Java实现截图小工具的完整代码
    目录写在前面效果展示代码展示项目结构设计思路项目测试写在前面 今天利用Java的图形用户界面GUI技术写了一个电脑截图小工具。本程序代码简单,涉及到异常处理,事件处理,图形用户界面等...
    99+
    2024-04-02
  • C++实现AVL树的完整代码
    AVL树的介绍 AVL树是一种自平衡的二叉搜索树,它通过单旋转(single rotate)和双旋转(double rotate)的方式实现了根节点的左子树与右子树的高度差不超过1...
    99+
    2024-04-02
  • Java实现画图的详细步骤(完整代码)
    一、导入依赖 <dependency> <groupId>net.coobird</groupId> <artifactId...
    99+
    2024-04-02
  • C语言实现ATM系统程序的完整代码
    实现效果如图: 代码如下: #include<stdio.h> #include<string.h> #include<conio.h> #...
    99+
    2024-04-02
  • C语言实现动态顺序表的示例代码
    目录顺序表概念及结构基本操作功能实现程序运行顺序表概念及结构 顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。 分...
    99+
    2022-11-13
    C语言 动态顺序表 C语言 顺序表
  • Java线性表的顺序表示及实现
    目录前言一、什么是顺序表?二、顺序表的实现1. 准备工作2. 获取顺序表的元素个数3. 获取顺序表当前的容量4. 顺序表是否为空5. 在指定索引位置添加元素6. 在顺序表末尾添加元素...
    99+
    2024-04-02
  • C++实现KDTree 附完整代码
    目录简介举例分割的作用一维二维n维关于kdtree的重要问题一.树的建立关键代码简介   k-d树(k-dimensional),是一种分割k维数据空间的数据...
    99+
    2024-04-02
  • 基于Java实现空间滤波完整代码
    空间滤波的定义 滤波的本义是指信号有各种频率的成分,滤掉不想要的成分,即为滤掉常说的噪声,留下想要的成分,这即是滤波的过程,也是目的。空间滤波是一种采用滤波处理的影像增强方法。其理论...
    99+
    2024-04-02
  • 怎么用Java实现顺序表
    这篇文章给大家分享的是有关怎么用Java实现顺序表的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、什么是顺序表?顺序表就是按照顺序存储方式存储的线性表,该线性表的结点按照逻辑次序依次存放在计算机的一组连续的存储...
    99+
    2023-06-27
  • Java实现顺序表和链表结构
    目录前言:顺序表定义:实现方法:代码实现:链表定义:分类:实现方法:代码实现:顺序表 & 链表总结前言: 线性表(linear list)是n个具有相同特性的数据元素的有限序...
    99+
    2024-04-02
  • 用python写一个福字(附完整代码)
    目录前言:一,扫五福活动如此火爆,为何不自己利用编程来生成福字!二,完整代码三,总结前言: 支付宝 2022 集五福活动正式开启 数据显示,过去六年累计参与支付宝集五福的人数已经超过...
    99+
    2024-04-02
  • 一文读懂Java中代码的加载顺序
    本篇文章为大家展示了一文读懂Java中代码的加载顺序,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Java中代码的加载顺序所能了解的知识点类的依赖关系static代码块的加载时间继承类中构造器的隐式...
    99+
    2023-05-31
    java 加载顺序 ava
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作