数据结构与算法(基于C++语法实现)

顺序列表

Hello,各位小伙伴,大家好!这是发布星空以后的第二次写博客。本次我将跟大家分享关于学习数据结构与算法的一些知识,数据结构与算法的后续,也会陆陆续续的更新,帮助大家更好的理解。
好了,今天我将要跟大家分享顺序列表的知识。

  1. 顺序列表的定义:n个数据元素的有限序列,其中n(n>=0)表示线性表的长度。
  2. 实现的操作增、删、改、查。(以后的数据结构基本上都是实现这几个操作)
    下面是顺序列表的代码块,有详细的注释帮助萌新理解哦,支持到vs2013上运行代码,只需做一点小小的修改,这个问题就留给小伙伴你了,一个简单的考验。
#define DataType int
Class SeqList
{public:SeqList(int size =defaultSize){if(size>0)//检查赋予的顺序表的大小,如果合法则分配相应大小的内存{maxsize=size;Elements =new DataType[maxsize];//分配内存大小}length=0;}int getLength(){return this.length;}~SeqList(){delete[] Elements;//回收内存}bool insertElement(DataType  data);//向指定位置插入元素bool deletElement(int location );//删除指定位置的元素DataType getElement(int location);//取得指定位置的元素bool cahngeElement(int location,DataType newData);//修改指定位置的元素值private:default const int defaultSize = 10;   DataType *Elements;int maxsize;//顺序表的最大大小int length;
}
bool SeqList::insertElements(DataType data)
{if(length >=maxsize)return false;//判定位置是否合法else{Elements[length]=data;length++;return true;}
}bool SeqList::deletElement(int location)
{if(length<0||location >=maxsize||location<0){  cout<<"顺序表已空或者位置非法,不得进行删除"<<endl;return false;//判定位置是否合法}else{for(int i=location;i<length;i++){Elements[i]=Elements[i+1];}length--;return true;}
}
DataType Seqlist::getElements(int location)//取出指定位置的数据
{if(location >maxsize||location<0){cout<<"你取元素的位置非法"<<endl;//判定位置是否合法return false;}else{length--;return Elements[location];}
}
bool SeqList::changeElement(int location ,DataType newData)
{if(location >maxsize||location <0){cout<<"操作位置非法"<<endl;//判定位置是否合法return false;}else{Elements[location]=newData;return true;}
}int main()
{SeqLsit list(10);//建立顺序表for(int i=0;i<10;i++){list.insertElements(i*20);//顺序表的初始化}for(int i=0;i<10;i++){cout<<list.getElements(i)<<" ";}//将顺序表中的元素输出cout<<endl;//删除索引为5的元素list.deletElement(5);//将删除后的表格输出for(int i=0;i<list.getLength();i++){cout<<list.getElement(i)<<" ";}cout<<endl;//将顺序表的索引为3的元素值改为88list.changeElement(3,88);//将更改之后的表格输出for(int i=0;i<list.getLength();i++){cout<<list.getElement(i)<<" ";}cout<<endl;return 0;
}

后续的相关的知识也会陆陆续续的发布出来,如果小伙伴感觉有用的话,多多点赞、收藏、转发(ps:表明转载处哦,),将实用的知识让更多的小伙伴了解。
感谢各位小伙伴的点赞关注收藏。

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

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

相关文章

python建筑案例_Python数据分析实战-链家北京二手房价分析

前言最近在自学Python&#xff0c;通过学习大家的分享案例&#xff0c;看到使用Python进行较多的主要4个方面&#xff1a;爬虫&#xff0c;数据处理&#xff0c;数据可视化以及机器学习建模。对我来说目标就是&#xff1a;熟练使用numpy pandas 进行数据清洗和预处理&#xff1…

C语言纯小白教学

大家好&#xff0c;很高兴来跟大家讲解C语言相关的知识&#xff0c;今天是大家一起学习C 语言的第一天&#xff0c;在接下来的几天我将向大家讲解完C语言的知识&#xff0c;坚持一下 很快就能迅速掌握C语言这一语言&#xff0c;废话不多说&#xff0c;开干。既然是第一天先给大…

execve系统调用_Linux系统编程——进程替换:exec 函数族

在 Windows 平台下&#xff0c;我们可以通过双击运行可执行程序&#xff0c;让这个可执行程序成为一个进程&#xff1b;而在 Linux 平台&#xff0c;我们可以通过 ./ 运行&#xff0c;让一个可执行程序成为一个进程。但是&#xff0c;如果我们本来就运行着一个程序&#xff08;…

数据结构之链表--单链表

Hello&#xff0c;大家好&#xff01;好久不见了&#xff0c;之前一直在忙于一些琐事&#xff0c;最近半个月内会将数据结构的各种数据结构实现出来&#xff0c;一个挺有意思的东西。 这次我将要介绍的是链表。链表有单链表&#xff0c;单向循环链表&#xff0c;双向链表&…

idea shell 使用linux_Linux使用shell定时任务实现ffmpeg视频转码和截图

Linux安装操作系统&#xff1a;CentOS7 ffmpeg版本&#xff1a;3.4.1安装先访问ffmpeg官网下载linux安装包 http://ffmpeg.org/download.html &#xff0c;这里我下载的是官方已经编译过的版本&#xff0c;别问我为啥不自己编译&#xff0c;因为我自己编译耗费了好久&#xff0…

链表之单循环链表

单链表之单循环链表 单向循环链表的关键所在是最后一个节点的next存储了头节点的地址&#xff0c;这是对单向循环链表的操作关键所在 接下来我将实现增、删、改、查这四项最基本的操作&#xff0c;剩下你想要什么操作自己可以根据对链表的理解添加对应的数据操作 后面main函数…

曾辉机器人_武昌理工学子在2020年中国机器人大赛中夺冠

“它在过弯的时候非常稳&#xff0c;而且速度快&#xff0c;跑完一圈的时间比第二名少十秒左右。”武昌理工学院学生余辉激动地说。11月27日从武昌理工学院获悉&#xff0c;在刚刚结束的2020中国机器人大赛中&#xff0c;武昌理工学院人工智能学院“晨旭队”&#xff0c;经过激…

链表之双向链表

又是敲代码学习的一天&#xff0c;虽然学的很痛苦&#xff0c;但是看到自己学完后有成果出来还是 很高兴的。 接下来废话不多说直接上代码&#xff0c;代码里有各个函数的解释说明&#xff0c;贯穿着我对这个双向链表的理解 //感觉这个双向链表&#xff0c;就是在单向链表中稍…

react手机机端css_react工程搭建系列之---移动端适配与antd-mobile高清适配方案

一、逻辑像素(css像素)与物理像素(设备像素)机型逻辑像素物理像素Scale Factoriphone 3GS320 x 480320 x 4801xiphone 4320 x 480640 x 9602xiphone 4S320 x 480640 x 9602xiphone 5320 x 568640 x 11362xiphone 5C320 x 568640 x 11362xiphone 5S320 x 568640 x 11362xiphone …

升级bios_华硕400系主板升级BIOS:静待11代酷睿CPU

1月份对PC玩家来说还有很多惊喜&#xff0c;AMD、NVIDIA、Intel都会在CES上推出新一代产品&#xff0c;其中Intel针对桌面端的产品是11代酷睿&#xff0c;代号Rocket Lake-S。Rocket Lake仍将采用14nm制造工艺&#xff0c;基本确定也将是Intel最后一代14nm处理器。CPU架构方面&…

win10共享打印错误0x0000006_Win10连接共享打印机提示0x80070035错误的解决办法

关于Win10连接共享打印机提示0x80070035错误&#xff0c;概括起来主要有以下几个方面。下面直接上解决方法&#xff0c;请碰到这个错误的朋友自己按照下面的方法一一排查。因为主要就是每个人安装的系统不一样&#xff0c;现在系统封装工具太多了&#xff0c;流程也傻瓜化了&am…

用vscode编写静态页面_开发中实用的VSCode插件推荐

本篇文章给大家介绍一下开发中实用的VSCode插件推荐。有一定的参考价值&#xff0c;有需要的朋友可以参考一下&#xff0c;希望对大家有所帮助。工欲善其事必先利其器&#xff0c;以下是本人为前端开发收集的vscode插件&#xff0c;有需要的话赶紧mark起来吧~一、代码片段类插件…

取得数组下标_《零基础C++入门教程》——(8)搞定二维数组与循环嵌套

一、学习目标了解二维数组的使用方法了解循环嵌套的使用方法目录预备第一篇&#xff0c;使用软件介绍在这一篇&#xff0c;C与C使用的软件是一样的&#xff0c;查看这篇即可&#xff1a;《零基础看得懂的C语言入门教程》——(二)简单带你了解流程 想了解编译原理和学习方法点这…

缺陷调研报告_工厂的缺陷的分析报告及产生原因

精彩文档锻造成形过程中的缺陷及其防止方法一、钢锭的缺陷钢锭有下列主要的缺陷&#xff1a;(1)缩孔和疏松钢锭中缩孔和疏松是不可避免的缺陷&#xff0c;但它们出现的部位可以控制。钢锭中顶端的保温冒口&#xff0c;造成钢液缓慢冷却和最后凝固的条件&#xff0c;一方面使锭身…

linux 的swap具体分析_Linux SWAP 深度解读

概述本文讨论的 swap基于Linux4.4内核代码 。Linux内存管理是一套非常复杂的系统&#xff0c;而swap只是其中一个很小的处理逻辑。希望本文能让读者了解Linux对swap的使用大概是什么样子。阅读完本文&#xff0c;应该可以帮你解决以下问题&#xff1a;1、 swap到底是干嘛的&…

物联卡的使用_物联卡在手机上使用有什么影响?网友:寿命分别是3个月,16天,9天...

个人使用物联卡是否合法&#xff1f;当然&#xff0c;个人是可以使用的&#xff0c;只不过是使用在除手机、平板以外的智能设备上。重点提醒&#xff1a;手机和平板除外。物联卡&#xff0c;是运营商为物流网服务企业提供的用于智能终端设备联网的&#xff0c;仅面对企业用户进…

多行文字cad提取数据_利用CAD自带的数据提取功能手动提取假表格至Excel

“吾生也有涯&#xff0c;而知也无涯&#xff0c;以有涯随无涯&#xff0c;殆已&#xff01;”&#xff0c;在已经有了免费的“源泉设计”插件可以自动提取假表格至Excel之后&#xff0c;笔者为什么还要讲解手动提取的方法&#xff1f;无他&#xff0c;生命在于折(zhuang)腾(bi…

gridview标题居中显示_Pr:制作片尾滚动字幕(旧版标题法)

本文介绍使用 Pr 的旧版标题设计器来制作传统片尾滚动字幕的方法。效果视频◆ ◆ ◆一般方法与步骤1、首先&#xff0c;将文字内容输入到一个文本文件中。按 Ctrl/Cmd A 全选&#xff0c;按 Ctrl/Cmd C 复制以备用。2、Pr菜单&#xff1a;文件/新建/旧版标题。3、点击“滚动…

mysql临时表空间_MySQL 5.7 深度解析: 临时表空间

先来说说临时表的概念。 临时表顾名思义&#xff0c;就是临时的&#xff0c;用完销毁掉的表。 数据既可以保存在临时的文件系统上&#xff0c;也可以保存在固定的磁盘文件系统上。 临时表有下面几种&#xff1a;全局临时表这种临时表从数据库实例启动后开始生效&#xff0c;在数…

mysql 从库状态_大神教你自动发现监控mysql从库状态

导读zabbix从库如果复制有问题&#xff0c;在主库机器有问题的时候&#xff0c;切为主就会导致数据的丢失。或者主从分离的时候&#xff0c;如果从库出现延时状态的话&#xff0c;会导致前端页面展示的数据不是为最新的数据。因此&#xff0c;监控mysql从库的状态是必要的。mys…