数据结构(Chapter Two -02)—顺序表基本操作实现

news2024/11/25 18:35:32

在前一部分我们了解线性表和顺序表概念,如果有不清楚可以参考下面的博客:

数据结构(Chapter Two -01)—线性表及顺序表-CSDN博客

首先列出线性表的数据结构:

#define MaxSize 50       //定义顺序表最大长度
typedef struct{
     ElemType data[MaxSize];//顺序表的元素
     int length;            //顺序表的当前长度
}SqList;                    //顺序表的类型定义

 接下来就是插入、删除、按值查找。

插入

顺序表,我们可以思考数组这一典型的顺序表数据结构,我们需要在第i个位置插入新元素e

这里定义顺序表为L,基本操作流程就是:

1、判断数据有效性和存储空间是否满,注意了可以插到表尾后一个元素,所以i>L.length+1

2、为第i个位置腾出位置,那就把第i个元素及之后的元素往后移,注意了这是从最后一个元素开始移的

3、在位置i放入元素e。

代码如下:

bool ListInsert(SqList &L,int i,ElemType e){
    if(i<1||i>L.length+1) //判断i的范围是否有效
    return false;
    if(L.length>=MaxSize)//当前存储空间已满,不能插入
    return false;
    for(int j =L.length;j>=i;j--)//将第i个元素及之后的元素后移
        L.data[j]=L.data[j-1];
    L.data[i-1]=e;      //在位置i处放e
    L.length++;         //线性表长度加1
    return true;
}

最好情况:表尾插入,不需要移,时间复杂度为O(1)

最坏情况:表首插入,需要执行n次移动操作,时间复杂度为O(n)

平均情况:O(n)

删除

删除第i个位置的元素,将删除的值赋给e

操作流程:

1、判断数据有效性

2、将删除的值赋给e

3、将第i+1个元素及后面元素往前移

bool ListDelete(SqList &L,int i,Elemtype &e){
    if(i<1||i>L.length)   //判断i的范围是否有效
    return false;
    e = L.data[i-1];        //将删除的元素赋值给e
    for(int j=i;j<L.length;j++)//将第i个位置后的元素前移
         L.data[j-1]=L.data[j];
    L.length--;               //线性表长度减1
    return true;
}

最好情况:删除表尾,不需移,时间复杂度O(1)

最坏情况:删除表首元素,需要移动除表头元素外的所有元素,时间复杂度为O(n)

平均情况:O(n)

 按值查找

查找第一个元素等于e的元素,并放回其位序(位序不等于下标,等于下标+1

操作流程:

遍历一遍表,当找到第一个符合的就直接放回位序,结束查找

int LocateElem(SqList L,ElemType e){
    for(int i =0;i<L.length;i++){//遍历一遍表,当找到第一个符合的就直接放回位序,结束查找
        if(L.data[i]==e)
        return i+1;
    }
    return 0;
}

最好情况:元素在表头,时间复杂度O(1)

最坏情况:元素在表尾,需要比较n次,时间复杂度O(n)

平均情况:O(n)

最后,拿着写代码来试一波效果!

#include <stdio.h>
#define MaxSize 20
typedef struct{
    int data[MaxSize];
    int length=0;
}SqList;

bool ListInsert(SqList &L,int i,int e){
    if(i<1||i>L.length+1) //判断i的范围是否有效
    return false;
    if(L.length>=MaxSize)//当前存储空间已满,不能插入
    return false;
    for(int j =L.length;j>=i;j--)//将第i个元素及之后的元素后移
        L.data[j]=L.data[j-1];
    L.data[i-1]=e;      //在位置i处放e
    L.length++;         //线性表长度加1
    return true;
}

bool ListDelete(SqList &L,int i,int &e){
    if(i<1||i>L.length)   //判断i的范围是否有效
    return false;
    e = L.data[i-1];        //将删除的元素赋值给e
    for(int j=i;j<L.length;j++)//将第i个位置后的元素前移
         L.data[j-1]=L.data[j];
    L.length--;               //线性表长度减1
    return true;
}

int LocateElem(SqList L,int e){
    for(int i =0;i<L.length;i++){//遍历一遍表,当找到第一个符合的就直接放回位序,结束查找
        if(L.data[i]==e)
        return i+1;
    }
    return 0;
}

int main()
{
    SqList L;
    int e = 0;

    for(int i=0;i<10;i++){//给顺序表赋值
        L.data[i]=10-i;
        L.length++;
    }
    
    printf("原始顺序表:");
    for(int i=0;i<L.length;i++) printf("%d ",L.data[i]);
    printf("\n");

    ListInsert(L,4,e);//第四个位置加12
    printf("增加后顺序表:");
    for(int i=0;i<L.length;i++) printf("%d ",L.data[i]);
    printf("\n");

    ListDelete(L,3,e);//第三个位置删除
    printf("删除后顺序表:");
    for(int i=0;i<L.length;i++) printf("%d ",L.data[i]);
    printf("\n");

    printf("查找0的位置:");
    int ans = LocateElem(L,0);//查找0的位置
    printf("%d",ans);
    
}

 运行结果如下:

最后的最后,可能会有友友对于代码参数里面的"&"会有疑惑?

看一下函数顺序表不加“&”的运行结果:

可以看出顺序表没有改变。这个“&”的作用是取地址或者引用,在函数的参数列表里面看到的“&”,通常代表了引用。引用可以看成是变量的别名,它的好处就是避免了复制参数的开销,并且允许函数直接访问和修改原始数据。注意了这个引用是可以修改原始数据的,就是修改main里面的顺序表L。没有引用,虽然完成了函数的流程,但修改不了原始数据表。

看一段代码:
 

void increment(int &x){
 x++;
}
int main(){
int y=5;
increment(y);//y的值由5变成6
}

 这个里面“&”为引用,当我们调用increment(y)时,我们实际上把y的地址传递到函数,而不是它的值,这样函数可以直接修改y,在函数参数中使用引用时,我们不需要在调用函数中再次使用&符号,因为在定义函数的时候已经定义了该参数需要引用。

可以敲敲代码试一下!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1321179.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【面试】Java最新面试题资深开发-微服务篇(1)

问题九&#xff1a;微服务 什么是微服务架构&#xff1f;它与单体架构相比有哪些优势和劣势&#xff1f;解释一下服务发现和服务注册是什么&#xff0c;它们在微服务中的作用是什么&#xff1f;什么是API网关&#xff08;API Gateway&#xff09;&#xff1f;在微服务中它有何…

什么是关键词排名蚂蚁SEO

关键词排名是指通过搜索引擎优化&#xff08;SEO&#xff09;技术&#xff0c;将特定的关键词与网站相关联&#xff0c;从而提高网站在搜索引擎中的排名。关键词排名对于网站的流量和用户转化率具有至关重要的影响&#xff0c;因此它是SEO工作中最核心的部分之一。 如何联系蚂…

任务十六:主备备份型防火墙双机热备

目录 目的 器材 拓扑 步骤 一、基本配置 配置各路由器接口的IP地址【省略】 1、配置BGP协议实现Internet路由器之间互联 2、防火墙FW1和FW2接口IP配置与区域划分 3、配置区域间转发策略 4、配置NAPT和默认路由 5、配置VRRP组&#xff0c;并加入Active/standby VGMP管…

06-部署knative-eventing

环境要求 For prototyping purposes 单节点的Kubernetes集群&#xff0c;有2个可用的CPU核心&#xff0c;以及4g内存&#xff1b; For production purposes 单节点的Kubernetes集群&#xff0c;需要至少有6个CPU核心、6G内存和30G磁盘空间多节点的Kubernetes集群中&#xff0c;…

Redis设计与实现之慢查询日志

目录 一、慢查询日志 1、相关数据结构 2、慢查询日志的记录 3、慢查询日志的操作 4、如何设置慢查询的阈值&#xff1f; 5、如何查看慢查询日志的内容&#xff1f; 6、如何分析慢查询日志以找出性能瓶颈&#xff1f; 7、如何优化慢查询以提高Redis的性能&#xff1f; 8…

人工智能_机器学习069_SVM支持向量机_网格搜索_交叉验证参数优化_GridSearchCV_找到最优的参数---人工智能工作笔记0109

然后我们再来说一下SVC支持向量机的参数优化,可以看到 这次我们需要,test_data这个是测试数据,容纳后 train_data这个是训练数据 这里首先我们,导出 import numpy as np 导入数学计算包 from sklearn.svm import SVC 导入支持向量机包 分类器包 def read_data(path): wit…

纵横字谜的答案 Crossword Answers

纵横字谜的答案 Crossword Answers - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 翻译后大概是&#xff1a; 有一个 r 行 c 列 (1<r,c<10) 的网格&#xff0c;黑格为 * &#xff0c;每个白格都填有一个字母。如果一个白格的左边相邻位置或者上边相邻位置没有白格&…

【Vue2】Component template should contain exactly one root element.

问题描述 [plugin:vite:vue2] Component template should contain exactly one root element. If you are using v-if on multiple elements, use v-else-if to chain them instead.原因分析 这个错误通常是由于 Vue 组件的模板中包含多个根元素导致的。Vue 要求组件模板中只…

【计算机网络】TCP协议——3. 可靠性策略效率策略

前言 TCP是一种可靠的协议&#xff0c;提供了多种策略来确保数据的可靠性传输。 可靠并不是保证每次发送的数据&#xff0c;对方都一定收到&#xff1b;而是尽最大可能让数据送达目的主机&#xff0c;即使丢包也可以知道丢包。 目录 一. 确认应答和捎带应答机制 二. 超时重…

Linear Regression线性回归(一元、多元)

目录 介绍&#xff1a; 一、一元线性回归 1.1数据处理 1.2建模 二、多元线性回归 2.1数据处理 2.2数据分为训练集和测试集 2.3建模 介绍&#xff1a; 线性回归是一种用于预测数值输出的统计分析方法。它通过建立自变量&#xff08;也称为特征变量&#xff09;和因变…

什么店生意好?C++采集美团商家信息做数据分析

最近遇到几个朋友&#xff0c;想要一起合伙投资一个实体店&#xff0c;不问类型&#xff0c;就看哪类产品相对比较受欢迎。抛除地址位置&#xff0c;租金的影响&#xff0c;我们之谈产品。因此&#xff0c;我熬了几个通宵&#xff0c;写了这么一段爬取美团商家商品信息的数据并…

Linux之grep、sed、awk

目录 1.grep 2.sed 3.awk 1.grep grep 擅长过滤查找&#xff0c;按行进行过滤 例&#xff1a; 当有用户对我们的主机进行爆破攻击时&#xff0c;我们可以使用grep将 ip 查找出来&#xff0c;进行封锁等处理 在 /var/log 目录下的 secure 文件中存放在用户登录连接信息&am…

JVM 垃圾回收详解

前言 什么是垃圾? 垃圾是指运行程序中没有任何引用指向的对象&#xff0c;需要被回收。 内存溢出和内存泄漏 内存溢出&#xff1a;经过垃圾回收之后&#xff0c;内存仍旧无法存储新创建的对象&#xff0c;内存不够溢出。 内存泄漏&#xff1a;又叫“存储泄漏”&#xff0…

Docker与微服务:构建和部署微服务架构的完整指南

微服务架构已经成为现代应用开发的主要范式之一&#xff0c;而Docker容器技术则为微服务的构建、部署和管理提供了理想的解决方案。本文将深入探讨如何使用Docker构建和部署微服务架构&#xff0c;提供更多示例代码和细致的指南&#xff0c;以帮助大家更全面地理解和运用这些关…

简单几步完成SVN的安装

介绍以及特点 SVN&#xff1a;Subversion&#xff0c;即版本控制系统。 1.代码版本管理工具 2.查看所有的修改记录 3.恢复到任何历史版本和已经删除的文件 4.使用简单上手快&#xff0c;企业安全必备 下载安装 SVN的安装分为两部分&#xff0c;第一部分是服务端安装&…

从零开始在Linux服务器配置并运行YOLO8+Web项目

✅作者简介&#xff1a;大家好&#xff0c;我是 Meteors., 向往着更加简洁高效的代码写法与编程方式&#xff0c;持续分享Java技术内容。 &#x1f34e;个人主页&#xff1a;Meteors.的博客 &#x1f49e;当前专栏&#xff1a; 神经网络&#xff08;随缘更新&#xff09; ✨特色…

Docker介绍,Docker安装

docker镜像仓库官网 一、Docker的基本概念 1.Docker的三大核心组件 docker 镜像 --------docker images docker 仓库---------docker registeries docker 容器---------docker containers 2.Docker 镜像 Docker镜像是运行docker容器时的只读模板&#xff0c;每一个镜像由一…

20、WEB攻防——PHP特性缺陷对比函数CTF考点CMS审计实例

文章目录 一、PHP常用过滤函数&#xff1a;1.1 与1.2 md51.3 intval1.4 strpos1.5 in_array1.6 preg_match1.7 str_replace CTFshow演示三、参考资料 一、PHP常用过滤函数&#xff1a; 1.1 与 &#xff1a;弱类型对比&#xff08;不考虑数据类型&#xff09;&#xff0c;甚至…

vue使用xlsx和xlsx-style导出xlsx文件并修改样式

1.下载依赖 npm install xlsx --save npm install file-saver --save npm install xlsx-style --save2.先修改xlsx-style的源码&#xff0c;一旦引入xlsx-style则会报错 在\node_modules\xlsx-style\dist\cpexcel.js 807行 的 var cpt require(’./cpt’ ‘able’); 改成 v…

Mongodb复制集架构

目录 复制集架构 复制集优点 复制集模式 复制集搭建 复制集常用命令 复制集增删节点 复制集选举 复制集同步 oplog分析 什么是oplog 查看oplog oplog大小 复制集架构 复制集优点 数据复制: 数据在Primary节点上进行写入&#xff0c;然后异步地复制到Secondary节点&a…