浅谈顺序表基本操作

简介: 浅谈顺序表基本操作

1713246790263.png


一、顺序表的构造函数


1.1接口


public interface IList {
        // 新增元素,默认在数组最后新增
        void add(int data);
        // 在 pos 位置新增元素
        void add(int pos, int data);
        // 判定是否包含某个元素
        boolean contains(int toFind);
        // 查找某个元素对应的位置
        int indexOf(int toFind);
        // 获取 pos 位置的元素
        int get(int pos);
        // 给 pos 位置的元素设为 value
        void set(int pos, int value);
        //删除第一次出现的关键字key,更新
        void remove(int toRemove);
        // 获取顺序表长度
        int size();
        // 清空顺序表
        void clear();
        // 打印顺序表,注意:该方法并不是顺序表中的方法,为了方便看测试结果给出的
        void display();
        //顺序表判满
        boolean isFull();
        //顺序表判空
        boolean isEmpty();
}


1.2 类定义


class MyArrayList implements IList {
    private int[] elem;
    private int usedSize;
    public static final int DEFAULT_SIZE=2;
    public MyArrayList(){
        this.elem=new int[DEFAULT_SIZE];
        this.usedSize=0;
    }
    public MyArrayList(int capacity){
        this.elem=new int[capacity];
    }
}

二、实现的功能


2.1检查容量


如果当前容量不足,则扩大2倍。


private void checkCapacity(){//检查容量
        if(isFull()){
            //扩容
            elem=Arrays.copyOf(elem,elem.length*2);
        }
    }

2.2表尾插入元素


在插入前,首先检查容量,容量不足就先扩容,之后继续插入。


public void add(int data) {
        checkCapacity();
        elem[this.usedSize]=data;
        this.usedSize++;
    }


2.3判满


 public boolean isFull() {
       /* if(usedSize==elem.length){
            return true;
        }
        return false;*/
        return usedSize==elem.length;
    }


2.4指定位置增加元素


首先要检查指定位置是否合法:


 private void checkPosOnAdd(int pos) throws PosIllegality{
        if(pos<0 || pos>usedSize){
            System.out.println("插入不合法!");
            throw new PosIllegality("插入元素下标异常:>"+pos);
        }
    }


public void add(int pos, int data) {
        try{
            checkPosOnAdd(pos);//检查pos位置合法性
        }catch (PosIllegality e){
            e.printStackTrace();//捕获异常并打印插入元素下标异常
            return;
        }
        checkCapacity();
        //1.从最后一个有效的数据开始往后移动,当i小于pos就结束
        for (int i = usedSize-1; i >=pos ; i--) {
            elem[i+1]=elem[i];
        }
        //2.存放元素到pos位置
        elem[pos]=data;
        //3.顺序表长度加一
        usedSize++;
    }


2.5判空


public boolean isEmpty() {
        return usedSize==0;
    }


2.6检查数据是否在表中


    public boolean contains(int toFind) {
        if(isEmpty()){
            return false;
        }
 
        for (int i = 0; i < usedSize; i++) {
            //如果是查找引用类型,一定要用equals方法!!!
            if(elem[i]==toFind){
                return true;
            }
        }
        return false;
    }


2.7查找指定元素的下标


   public int indexOf(int toFind) {
        if(isEmpty()){
            return -1;
        }
        for (int i = 0; i < usedSize; i++) {
            //如果是查找引用类型,一定要用equals方法!!!
            if(elem[i]==toFind){
                return i;
            }
        }
        return -1;
    }


2.8获取指定位置的元素


同样需要检查指定位置是否合法:


  private void checkPosOnGetAndSet(int pos) throws PosIllegality{
        if(pos<0 || pos>=usedSize){
            System.out.println("获取元素下标不合法!");
            throw new PosIllegality("获取元素下标异常:>"+pos);
        }
    }


public int get(int pos)throws MyArrayListEmpty {
        if(isEmpty()){
            throw new MyArrayListEmpty("顺序表为空!!");
        }
        checkPosOnGetAndSet(pos);
        return elem[pos];
    }


2.9设置表中指定位置的元素


public void set(int pos, int value) {
        checkPosOnGetAndSet(pos);
        elem[pos]=value;
    }


2.10删除元素


删除元素,首先要找到要删除元素的下标,可以调用上面写过的函数。


 public void remove(int toRemove) {
        /**
         * 1.找到删除的数字下标
         * 2.挪动数据
         * 3.usedSize--
         */
        int index=indexOf(toRemove);
        if(index==-1){
            System.out.println("无此元素:>"+toRemove);
            return;
        }
        for (int i = index; i < usedSize-1; i++) {
            elem[i]=elem[i+1];
        }
        usedSize--;
    }


2.11获取元素个数


  public int size() {
        return this.usedSize;
    }


2.12清空顺序表


 public void clear() {
        this.usedSize=0;
        //如果是引用数据类型的清空,通过for循环把元素置空即可
    }


2.13显示顺序表


   public void display() {
        for (int i = 0; i < this.usedSize; i++) {
            System.out.println(elem[i]+" ");
        }
        System.out.println();
    }


相关文章
|
存储 Serverless C语言
[笔记]Python计算机视觉编程《一》 基本的图像操作和处理(三)
[笔记]Python计算机视觉编程《一》 基本的图像操作和处理(三)
250 0
|
定位技术
欧洲创业地图:获投最多的创企股权融资35亿美元|全球快讯
科技繁荣正在扩散至整个欧洲大陆,创业公司不断出现在伦敦、柏林、斯德哥尔摩等成熟创新中心之外的地方。
|
关系型数据库 MySQL Linux
linux自动启动mysql的方法
linux自动启动mysql的方法http://www.bieryun.com/3225.html 最简单的方法,直接编辑/etc/rc.local配置文件 先直接关闭现在启动的mysqld服务 msyqladmin -uroot -p -S /tmp/mysql.
1669 0
The system clock has been set back more than 24 hours
由于破解调试需要,更改了系统时间,打开ArcMap会出现"The system clock has been set back more than 24 hours"的错误,原因是由于你更改过系统时间,或者是系统时间与正常时间不正确。
1970 0
|
24天前
|
人工智能 自然语言处理 Shell
🦞 如何在 OpenClaw (Clawdbot/Moltbot) 配置阿里云百炼 API
本教程指导用户在开源AI助手Clawdbot中集成阿里云百炼API,涵盖安装Clawdbot、获取百炼API Key、配置环境变量与模型参数、验证调用等完整流程,支持Qwen3-max thinking (Qwen3-Max-2026-01-23)/Qwen - Plus等主流模型,助力本地化智能自动化。
34037 135
🦞 如何在 OpenClaw (Clawdbot/Moltbot) 配置阿里云百炼 API
|
6天前
|
人工智能 自然语言处理 监控
OpenClaw skills重构量化交易逻辑:部署+AI全自动炒股指南(2026终极版)
2026年,AI Agent领域最震撼的突破来自OpenClaw(原Clawdbot)——这个能自主规划、执行任务的智能体,用50美元启动资金创造了48小时滚雪球至2980美元的奇迹,收益率高达5860%。其核心逻辑堪称教科书级:每10分钟扫描Polymarket近千个预测市场,借助Claude API深度推理,交叉验证NOAA天气数据、体育伤病报告、加密货币链上情绪等多维度信息,捕捉8%以上的定价偏差,再通过凯利准则将单仓位严格控制在总资金6%以内,实现低风险高频套利。
3023 14
|
19天前
|
人工智能 安全 机器人
OpenClaw(原 Clawdbot)钉钉对接保姆级教程 手把手教你打造自己的 AI 助手
OpenClaw(原Clawdbot)是一款开源本地AI助手,支持钉钉、飞书等多平台接入。本教程手把手指导Linux下部署与钉钉机器人对接,涵盖环境配置、模型选择(如Qwen)、权限设置及调试,助你快速打造私有、安全、高权限的专属AI助理。(239字)
7386 21
OpenClaw(原 Clawdbot)钉钉对接保姆级教程 手把手教你打造自己的 AI 助手
|
18天前
|
人工智能 机器人 Linux
OpenClaw(Clawdbot、Moltbot)汉化版部署教程指南(零门槛)
OpenClaw作为2026年GitHub上增长最快的开源项目之一,一周内Stars从7800飙升至12万+,其核心优势在于打破传统聊天机器人的局限,能真正执行读写文件、运行脚本、浏览器自动化等实操任务。但原版全英文界面对中文用户存在上手门槛,汉化版通过覆盖命令行(CLI)与网页控制台(Dashboard)核心模块,解决了语言障碍,同时保持与官方版本的实时同步,确保新功能最快1小时内可用。本文将详细拆解汉化版OpenClaw的搭建流程,涵盖本地安装、Docker部署、服务器远程访问等场景,同时提供环境适配、问题排查与国内应用集成方案,助力中文用户高效搭建专属AI助手。
5178 12