Java实现顺序表的增删查改功能

创建顺序表

在java语言中要实现顺序表,首先创建一个类,因为顺序表本身就像数组,所以我们这里定义一个int类型的数组和usedata为有效数据,构造方法里先申请可以存放10个数据的空间。

public class MyArraylist1 {
    public int[] elem;//存储数据的有效个数
    public int usedata;//有效数据的个数

    //构造方法
    public MyArraylist1() {
        this.elem = new int[10];
    }

主要实现以下方法

public void add(int pos,int data)//添加元素

 public int search(int tofind)//找一个元素返回下标

 public void remove(int toRemove)//删除第一次出现的关键字toRemove

 public void setPos(int pos,int value)//给 pos 位置的元素设为 value

 public void display()//打印元素

插入元素

插入元素也就是添加元素,在这之前,我们应该思考以下几步

  • 判断顺序表是否满了
  • pos位置(插入元素的下标)是否合法
  • 怎么插入元素

通过思考我们知道,if(this.elem.length == this.usedata)时,顺序表就满了,可以通过Arrays.copyOf函数扩充,如果if (pos<0 || pos>this.usedata)说明不合法,通过this.elem[i+1] = this.elem[i],每个元素向后位移的方法插入元素

//添加元素
    public void add(int pos,int data) {
        //1.判断顺序表是否为满
        if (this.elem.length == this.usedata) {
            System.out.println("满了,扩充");
            this.elem = Arrays.copyOf(this.elem,this.elem.length*2);
        }
        //2,pos位置有效性
        if (pos<0 || pos>this.usedata) {
            System.out.println("不合法");
            return;
        }
        //3,插入
        for (int i = this.usedata-1; i>=pos  ; i--) {
            this.elem[i+1] = this.elem[i];
        }
        this.elem[pos] = data;
        usedata++;
    }

查找元素

查找第一个出现的元素我们通过返回它的下标,用search()实现,在查找之前我们先判断顺序表是否有数据,如果没有,实现手动抛出一个异常提示顺序表为空,如果没有找到想查找的元素,我们这里暂时返回一个 -1的值

//查找一个元素返回下标
    public int search(int tofind) {
        //1.判断顺序表是否为空
        if (this.usedata == 0) {
            throw new RuntimeException("顺序表为空");
        }
        //2.查找
        for (int i = 0; i < this.usedata ; i++) {
            if (this.usedata == tofind) {
                return i;
            }
        }
        return -1;

删除元素

在删除元素之前,我们需要先思考以下几个问题

  • 怎么判断删除元素是否存在
  • 怎么删除
  • 万一要删除的数出现了不止一次

通过思考,我们可以直接调用刚刚所写的查找元素的方法,用index来接收数组的下标,如果返回值是 -1,说明要删除的元素不存在。否则index就为要删除元素的下标,从index开始后一个元素向前一个元素覆盖this.elem[i] = this.elem[i+1],最后usedata--

 //删除第一次出现的关键字toRemove
    public void remove(int toRemove) {
        //1.判断是否含有这个关键字
        int index = search(toRemove);
        if (index == -1) {
            System.out.println("删除的关键字不存在");
            return;
        }
        //2.删除
        //主要理解i< this.usedsize-1,画图易懂,比如有1,2,3三个数,要删除0号下标,i=0;i<2;i++,从后向前覆盖两次。
        for (int i = index; i < this.usedata-1 ; i++) {
            this.elem[i] = this.elem[i+1];
        }
        usedata--;
    }

修改元素

修改元素就和前面的查找元素的方式看视很相似,其实不然,查找元素的方法里,我们只写了一个参数,就是说它只能查找第一个出现的元素返回的下标,修改元素这里我们提供两个参数pos位置和value值,在实现时应该考虑pos有效性,如果if (pos<0 || pos>=this.usedata)说明不合法。

// 给 pos 位置的元素设为 value
    public void setPos(int pos, int value) {
        //1.判断顺序表是否为空
        if (this.usedata == 0) {
            throw new RuntimeException("顺序表为空");
        }
        //2.判断pos位置有效性
        if (pos<0 || pos>=this.usedata) {
            return;
        }
        //3.修改值为value
        this.elem[pos] =value;
    }

打印元素

//打印元素
    public void display() {
        for (int i = 0; i <this.usedata ; i++) {
            System.out.print(this.elem[i]+" ");
        }
        System.out.println();
    }

最后实现在main方法里面实现

public class TestList1 {
    public static void main(String[] args) {
        MyArraylist1 myArraylist1 = new MyArraylist1();
        myArraylist1.add(0,1);
        myArraylist1.add(0,2);
        myArraylist1.add(0,3);
        myArraylist1.add(0,4);
        myArraylist1.add(0,5);
        System.out.println("========================查找===========================");
        myArraylist1.display();
        System.out.println("查找元素下标为:"+myArraylist1.search(1));
        System.out.println("查找元素下标为:"+myArraylist1.search(3));
        System.out.println("查找元素下标为:"+myArraylist1.search(5));
        System.out.println("========================删除===========================");
        myArraylist1.remove(1);
        myArraylist1.remove(5);
        myArraylist1.display();
        System.out.println("========================修改===========================");
        myArraylist1.setPos(0,2);
        myArraylist1.setPos(2,4);
        myArraylist1.display();
    }
}

打印结果

到此这篇关于Java实现顺序表的增删查改的文章就介绍到这了,更多相关Java实现增删查改内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Java通过MyBatis框架对MySQL数据进行增删查改的基本方法

    1. 查询 除了单条记录的查询,这里我们来尝试查询一组记录. IUserMapper接口添加下面方法: List<User> getUsers(String name); 在User.xml中添加: <resultMap type="User" id="userList"><!-- type为返回列表元素的类全名或别名 --> <id column="id" property="id"

  • Java操作Mongodb数据库实现数据的增删查改功能示例

    本文实例讲述了Java操作Mongodb数据库实现数据的增删查改功能.分享给大家供大家参考,具体如下: 首先,我们在windows下安装mongodb数据库,安装教程可查看前面一篇文章:http://www.jb51.net/article/85605.htm 代码如下: package io.mogo; import java.util.Map; import org.apache.commons.lang3.StringUtils; import com.mongodb.BasicDBObj

  • java数据结构实现顺序表示例

    复制代码 代码如下: import java.util.Arrays;/** * 顺序线性表的实现 */public class LineList<E>{ private int size;   //长度 private Object[] array;  //底层数组 private final int default_length=16; //默认长度 /**  * 无参构造方法  */ public LineList(){  size = 0;  //使用默认长度构造数组  array =

  • Java操作redis实现增删查改功能的方法示例

    本文实例讲述了Java操作redis实现增删查改功能的方法.分享给大家供大家参考,具体如下: 首先,我们需要在windows下配置一个redis环境,具体配置教程请看:http://www.jb51.net/article/96230.htm 然后需要导入:jedis-2.7.3.jar这个包,看如下代码: package redis.main; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; imp

  • JAVA模拟新增顺序表及单链表

    最近在回顾大学学的数据结构,这里给大家用java模拟顺序表和单链表的新增 1顺序表新增 /** * 顺序表 * * @author cjd * */ public class ArrayList { private Object[] elementData; // 底层是一个数组,目前还没有确定长度 private int size; // 不是数组分配了几个空间,而是元素的个数 public ArrayList() { this(4); } public ArrayList(int initi

  • Java实现顺序表的增删查改功能

    创建顺序表 在java语言中要实现顺序表,首先创建一个类,因为顺序表本身就像数组,所以我们这里定义一个int类型的数组和usedata为有效数据,构造方法里先申请可以存放10个数据的空间. public class MyArraylist1 { public int[] elem;//存储数据的有效个数 public int usedata;//有效数据的个数 //构造方法 public MyArraylist1() { this.elem = new int[10]; } 主要实现以下方法 p

  • Java数据结构之链表的增删查改详解

    一.链表的概念和结构 1.1 链表的概念 简单来说链表是物理上不一定连续,但是逻辑上一定连续的一种数据结构 1.2 链表的分类 实际中链表的结构非常多样,以下情况组合起来就有8种链表结构. 单向和双向,带头和不带头,循环和非循环.排列组合和会有8种. 但我这只是实现两种比较难的链表,理解之后其它6种就比较简单了 1.单向不带头非循环链表 2.双向不带头非循环链表 二.单向不带头非循环链表 2.1 创建节点类型 我们创建了一个 ListNode 类为节点类型,里面有两个成员变量,val用来存储数值

  • Python操作mysql数据库实现增删查改功能的方法

    本文实例讲述了Python操作mysql数据库实现增删查改功能的方法.分享给大家供大家参考,具体如下: #coding=utf-8 import MySQLdb class Mysql_Oper: def __init__(self,host,user,passwd,db): self.host=host self.user=user self.passwd=passwd self.database=db def db_connecet(self): try: #连接 conn=MySQLdb.

  • ASP.NET实现电影票信息的增删查改功能

    题目 1.使用Code First技术创建一个Movie数据模型. public class Movie { public int ID { get; set; } //电影编号 public string Title { get; set; } //电影名称 public DateTime ReleaseDate { get; set; } //上映时间 public string Genre { get; set; } //电影类型 public decimal Price { get; s

  • PHP实现数据库的增删查改功能及完整代码

    本文用到:jquery.tp框架 TP_3.2.2/Application/Home/Controller/StuController.class.php <?php /** * Created by PhpStorm. * User: root * Date: 2018/4/17 * Time: 16:32 */ namespace Home\Controller; use Think\Controller; class StuController extends Controller { p

  • 浅谈Android手机联系人开发之增删查改功能

    最近在做手机联系人的功能模块的时候,遇到了很多的坑,在网上搜索的有一些所谓的最全的手机联系人开发的介绍还存在一些bug,所以我把我最近的项目心得和方法写下来,既能帮助大家减少了解android开发手机联系人的门槛,好,废话少说,接下来直奔主题. 一.深入浅出手机联系人的前奏(小米手机的data表跟模拟器的data表不一样) 1.手机联系人主要是对contacts2.db数据库表的操纵,这个数据库中有三个表是比较重要的,分别是data,raw_contacts,mimetyps这三个表.在下面的增

  • golang使用json格式实现增删查改的实现示例

    需求和思路 在一般的小项目或者一个小软件,例如客户端之类的小程序中,可能会需要数据的持久化.但是使用一般的数据库(Mysql)之类的不合适.使用sqlite3这种嵌入式的是个较好的方法,但是Go语言中sqlite3的库是C语言的,Cgo不支持跨平台编译.正是由于这种需求,才想到使用json格式将数据直接保存在文件中. 具体的思路是怎么样呢? 在Go语言中如果要将数据转化成json格式的话,有两种格式 struct 和 map. 如果同时需要增删查改功能的话,将map作为中间格式是比较合适的.接下

  • Java Mybatis框架增删查改与核心配置详解流程与用法

    目录 Mybatis简介 Mybatis开发步骤: Mybatis的映射文件概述 Mybatis的增删改查操作 MyBatis的核心配置文件概述 MyBatis核心配置文件层级关系 MyBatis常用配置解析 Mybatis相应API 原始JDBC操作 原始jdbc操作(查询数据) 原始jdbc操作(插入数据) 原始jdbc操作的分析原始jdbc开发存在的问题如下: ①数据库连接创建.释放频繁造成系统资源浪费从而影响系统性能 ②sql 语句在代码中硬编码,造成代码不易维护,实际应用sql变化的可

随机推荐