当前位置: 首页 > article >正文

数据结构实验1.1: 顺序表的操作及其应用

这里写自定义目录标题

  • 一、实验目的
  • 二、注意事项
  • 三、实验内容
    • (一)问题描述
    • (二)基本要求
  • 四,操作步骤
    • (一)使用visual studio集成环境编写程序
  • 五,示例代码
  • 六,运行效果


一、实验目的

1.掌握使用C++/VC环境上机调试程序的基本方法;
2.掌握线性表顺序存储的概念,加深对顺序存储数据结构的理解;
3.掌握顺序表的基本运算及简单应用问题,逐步培养解决实际问题的编程能力。

二、注意事项

1.在磁盘上创建一个目录,专门用于存储数据结构实验的程序。
2.建议实验者不要过分依赖本书提供的算法或参考程序,实验者对每一个实验题目可独立进行算法分析与设计,独立设计完整的上机程序。只有经过严格的训练,才能显著提高算法分析与设计能力、程序设计能力,更有助于《数据结构》课程知识体系的理解和掌握。

三、实验内容

(一)问题描述

设有线性表(34,12,45,64,28,36,45),采用顺序存储结构。编程实现有关顺序表的下列基本操作:
(1)初始化一个空的顺序表;
(2)在顺序表的第i个位置上插入一个新元素;
(3)在顺序表中查找指定值的元素位置;
(4)删除顺序表中的第i个元素;
(5)删除顺序表中指定值的元素;
(6)输出顺序表中的所有元素值。

(二)基本要求

(1)采用动态分配方式设计顺序表的存储结构;
(2)用反复执行插入操作的方式建立线性表;
(3)每完成一个步骤,必须及时输出顺序表中的所有元素,便于观察操作结果;
(4)完善参考程序,并在参考程序中的下划线处填上适当的语句或文字;
(5)设计测试用例,上机调试、测试完善后的参考程序,保存和打印测试结果,对测试结果进行分析,包括算法效率分析;

四,操作步骤

(一)使用visual studio集成环境编写程序

1.双击启动程序。
在这里插入图片描述

2.选择“新建项目”。
在这里插入图片描述
3.选择“空项目”——输入“项目名称”——单击确认按钮。
在这里插入图片描述

4.添加项目文件,右击“源文件”——选择“添加”——单击“新建项”。
在这里插入图片描述

5.这里选择C++——输入文件名称(不要输入中文,建议输入英文或拼音)——单击“添加”按钮。
在这里插入图片描述

6.在C++文件中编写代码,可以先自己编写,在与示例代码进行对比。(实例代码在五,示例代码)。
在这里插入图片描述

7.右击编写的文件——单击编译。
在这里插入图片描述

8.查看编译结果,成功则如下图所示,失败的话会给出出错位置,进行修改就可以重新编译。
在这里插入图片描述

五,示例代码

#define OVERFLOW -1
#define OK 1
#define ERROR 0
#define MAXSIZE 6   		//空间初始分配量,为了检验空间扩展,初值取小一点
#define INCREMENT 10	//空间分配增量
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>typedef int Status;
typedef int ElemType;
typedef struct {ElemType *elem;     		//存储空间基址int length;		  		//当前顺序表中实际元素的个数int listsize;	 			//当前分配的存储容量
} SqList;Status InitList(SqList &L)		// 初始化顺序表
{L.elem=(ElemType *)malloc(MAXSIZE*sizeof(ElemType));if( !L.elem )  exit(OVERFLOW); // 1. 判断内存分配是否成功L.length=0;L.listsize = MAXSIZE; // 2. 初始化当前分配的存储容量return OK;
}Status  InsertList (SqList &L, int i, ElemType e) {//将新元素e插入到顺序表L的第i个位置上if ( i < 1 || i > L.length + 1 )  return  ERROR; // 3. 判断插入位置是否合法ElemType  *p;int  j;if( L.length >= L.listsize ) {		//若顺序表已满,则需扩充空间p=(ElemType *)realloc(L.elem, (L.listsize+INCREMENT)*sizeof(ElemType));if (!p) exit (OVERFLOW);L.elem=p;L.listsize += INCREMENT;}for(j = L.length-1; j>=i-1; --j) L.elem[j+1]=L.elem[j];L.elem[i-1] = e; // 5. 插入新元素L.length++;return OK;
}// InsertList void PrintList(SqList L)				// 输出顺序表元素
{int  i;for(i=0; i < L.length; i++) // 6. 遍历顺序表printf("%d  ", L.elem[i]);printf("\n");
}int SearchList(SqList L, ElemType e)
// 在顺序表L中查找值为e的第一个元素,查找成功返回元素的位置,失败返回-1
{int i;for(i=0; i<L.length; i++)if( L.elem[i] == e )   		// 7. 找到相同的元素,返回位置return i;return -1;
}int Del_List1(SqList &L, ElemType e)
// 在顺序表L中删除值为e的第一个元素,删除成功返回元素位置,失败则返回-1
{int i, j;for(i=0; i<L.length; i++)if(L.elem[i]==e)              		// 找到相同的元素break;if(i<L.length){for(j=i; j<L.length -1; j++)			// 删除L.elem[j] = L.elem[j+1]; // 8. 元素前移L.length--;return i;}return -1;
}Status  Del_List2(SqList &L, int i, ElemType &e)
// 在顺序表L中删除第i个元素,被删元素用参数e带回
{if ( i < 1 || i > L.length ) return  ERROR; // 9. 判断删除位置是否合法int  j;e=L.elem[i-1];for(j=i; j<L.length; j++) L.elem[j-1] = L.elem[j]; // 10. 元素前移--L.length;return OK;
}void main()
{SqList  LL;ElemType x;int r,i;printf("(1)初始化顺序表……\n");if( !InitList(LL) )  return;printf("  初始化成功!\n");printf("(2)顺序表的插入操作……\n");while(1)      {printf("  输入插入元素的值(0:结束)=>");scanf("%d", &x);if( x == 0 )  break;printf("    输入插入位置:");scanf("%d", &r);InsertList(LL, r, x); // 12. 调用插入函数printf("  线性表输出:");PrintList(LL); // 13. 输出顺序表}printf("(3)顺序表上的查找操作……\n");while(1)      //在顺序表中查找指定值的元素,输出该元素所在位置{printf("  输入查找元素的值(0:结束)=>");scanf("%d", &x);if(x==0)break;r= SearchList(LL, x); // 14. 调用查找函数if(r<0)printf("    没找到!\n");elseprintf("  有符合条件的元素,位置为:%d\n", r+1);}printf("(4)顺序表中指定元素值的删除操作……\n");while(1)        //在顺序表中删除指定值的元素{printf("  输入删除元素的值(0:结束)=>");scanf("%d", &x);if(x==0)break;r= Del_List1(LL, x); // 15. 调用删除函数if(r<0)printf("  没找到\n");else {printf("  删除成功!被删元素的位置是:%d\n  线性表输出:", r+1);PrintList(LL);}}printf("(5)顺序表中指定元素位置的删除操作……\n");while(1) {printf("  输入删除元素的位置(0:结束)=>");scanf("%d", &r);if(r==0)break;if( r < 1 || r > LL.length )printf("  位置越界!\n");else {ElemType deleted;Del_List2(LL, r, deleted);printf("  线性表输出:");PrintList(LL);}}
}

六,运行效果

1.单击调试按钮,运行程序。
在这里插入图片描述
2.成功运行效果图。
在这里插入图片描述

3.按照需求,调试程序。
在这里插入图片描述

在这里插入图片描述

相关文章:

数据结构实验1.1: 顺序表的操作及其应用

这里写自定义目录标题 一、实验目的二、注意事项三、实验内容&#xff08;一&#xff09;问题描述&#xff08;二&#xff09;基本要求 四&#xff0c;操作步骤&#xff08;一&#xff09;使用visual studio集成环境编写程序 五&#xff0c;示例代码六&#xff0c;运行效果 一、…...

基于yolov11的汽车损伤检测系统python源码+onnx模型+评估指标曲线+精美GUI界面

【算法介绍】 基于YOLOv11的汽车损伤检测系统是一种先进的计算机视觉技术&#xff0c;旨在快速准确地识别汽车的各种损伤类型。该系统利用YOLOv11模型的强大性能&#xff0c;实现了对车辆损伤的精确检测与分类。 该系统能够识别的损伤类型包括裂纹&#xff08;crack&#xff…...

OpenCV 图形API(2)为什么需要图形API?

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 G-API背后的动机 G-API模块为OpenCV带来了基于图的执行模型。本章简要描述了这种新模型如何在两个方面帮助软件开发者&#xff1a;优化和移植图像处理算法…...

基于Spring Boot的平面设计课程在线学习平台系统的设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…...

esp32 idf中的外部组件

通常外部组件都定义在“main/idf_component.yml”里面。 例如小智智能语音的外部组件&#xff1a; ## IDF Component Manager Manifest File dependencies:waveshare/esp_lcd_sh8601: "1.0.2"espressif/esp_lcd_ili9341: "1.2.0"espressif/esp_lcd_gc9a01…...

【JavaEE】MyBatis - Plus

目录 一、快速使用二、CRUD简单使用三、常见注解3.1 TableName3.2 TableFiled3.3 TableId 四、条件构造器4.1 QueryWrapper4.2 UpdateWrapper4.3 LambdaQueryWrapper4.4 LambdaUpdateWrapper 五、自定义SQL 一、快速使用 MyBatis Plus官方文档&#xff1a;MyBatis Plus官方文档…...

经典卷积神经网络LeNet实现(pytorch版)

LeNet卷积神经网络 一、理论部分1.1 核心理论1.2 LeNet-5 网络结构1.3 关键细节1.4 后期改进1.6 意义与局限性二、代码实现2.1 导包2.1 数据加载和处理2.3 网络构建2.4 训练和测试函数2.4.1 训练函数2.4.2 测试函数2.5 训练和保存模型2.6 模型加载和预测一、理论部分 LeNet是一…...

【2】数据结构的单链表章

目录标题 单链表的定义单链表的初始化单链表的建立头插法创建尾插法创建 查找操作按序号查找按内容查找 插入操作删除操作合并操作 单链表总代码与调试 单链表的定义 结点&#xff08;Node&#xff09;的定义&#xff1a;数据域&#xff08;data&#xff09;和指针域&#xff…...

Linux(十一)fork实例练习、文件操作示例及相关面试题目分享

一、fork实例练习 1、思考下面这段代码的打印结果是什么&#xff1f; #include<stdio.h> #include<unistd.h> #include<assert.h> #include<stdlib.h>int main(){int i0;for(;i<2;i){fork();printf("A\n");} exit(0); }所以一共打印6…...

android Fragment使用

在 Android Fragment 中&#xff0c;导入 id&#xff08;findViewById&#xff09;并给控件赋值的逻辑通常应该写在 onViewCreated() 方法中&#xff0c;而不是 onCreateView()。 Fragment 生命周期 & 适合的位置 方法作用适合的操作onCreateView()创建并返回 Fragment 的…...

open3d教程 (三)点云的显示

官方文档位置&#xff1a; Visualization - Open3D 0.19.0 documentationhttps://www.open3d.org/docs/release/tutorial/visualization/visualization.html核心方法&#xff1a; o3d.visualization.draw_geometries([几何对象列表]) import open3d as o3dprint("Load …...

根据模板将 Excel 明细数据生成 Txt 文档|邮件合并

在日常办公中&#xff0c;我们常常会遇到需要批量生成文档的任务。以往&#xff0c;若要将 Excel 中的每一条数据都转化为单独的文档&#xff0c;且文档部分内容依据 Excel 数据动态变化&#xff0c;手动操作不仅繁琐&#xff0c;还容易出错。现在&#xff0c;有一种便捷的方法…...

【学Rust写CAD】22 双圆径向渐变的结构体(two_circle_radial_gradient.rs)

源码 //two_circle_radial_gradient.rs //! 定义双圆径向渐变的结构体和相关功能/// 表示一个双圆径向渐变的源 /// /// 该结构体描述了两个圆之间的渐变&#xff0c;支持矩阵变换和颜色查找表优化 #[derive(Debug, Clone, PartialEq)] pub struct TwoCircleRadialGradientSou…...

LVGL Dropdown和Calendar详解

LVGL Dropdown和Calendar详解 一、Dropdown详解创建和初始化设置下拉框选项获取选项获取选中项文本&#xff1a;获取选中项索引&#xff1a;设置选中项&#xff1a; 事件处理其他功能和样式设置设置下拉按钮样式&#xff1a;设置下拉框方向&#xff1a;设置最大高度&#xff1a…...

AISEO (GEO )中的知识图谱

一、知识图谱在AI SEO中的概念与结构 1. 知识图谱是什么&#xff1f; 定义&#xff1a;知识图谱&#xff08;Knowledge Graph&#xff09;是一种以图结构组织的语义网络&#xff0c;由实体&#xff08;Entity&#xff09;、**关系&#xff08;Relation&#xff09;和属性&…...

Vulnhub-zico2靶机打靶记录

本篇文章旨在为网络安全渗透测试靶机教学。通过阅读本文&#xff0c;读者将能够对渗透Vulnhub系列zico2靶机有一定的了解 一、信息收集阶段 靶机下载地址&#xff1a;https://download.vulnhub.com/zico/zico2.ova 因为靶机为本地部署虚拟机网段&#xff0c;查看dhcp地址池设…...

(041)05-01-自考数据结构(20331)树与二叉树大题总结

实际考试中,计算题约占40%,推理题约占30%,算法设计题约占30%。建议重点练习遍历序列相关的递归分治解法, 知识拓扑 知识点介绍 一、计算题类型与解法 1. 结点数量计算 题型示例: 已知一棵完全二叉树的第6层有8个叶子结点,求该二叉树最多有多少个结点? 解法步骤: 完…...

Python----机器学习(KNN:使用数学方法实现KNN)

一、原理 以下是K最近邻&#xff08;K-Nearest Neighbors&#xff0c;简称KNN&#xff09;算法的基本流程&#xff0c;用于对给定点进行分类预测。 1. 获得要预测的点 point_predict 。 2. 计算训练点集 point_set_train 中各点到要预测的点 表 l ist_L2_distance 。 3. 对 poi…...

网络攻防快速入门笔记pwn | 02 栈溢出题型 | 2.2 ret2libc

上一篇&#xff1a;网络攻防快速入门笔记pwn | 02 栈溢出题型 | 2.1 ret2text和ret2shellcode 下一篇&#xff1a;网络攻防快速入门笔记pwn | 02 栈溢出题型 | 2.3 ret2syscall 欢迎关注~ ret2libc 一、 什么是ret2libc&#xff08;一&#xff09;ret2lib的概念&#xff08;…...

Edge浏览器快速开启IE模式

一些老旧的网站&#xff0c;仅支持Internet Explorer&#xff08;IE&#xff09;浏览器访问。 然而&#xff0c;出于安全性的考虑&#xff0c;可能会遇到限制IE浏览器使用的情况。 Microsoft Edge浏览器提供了兼容性配置&#xff0c;可以通过IE模式访问这些网站。 以下是两种…...

技术长期主义:用本分思维重构JavaScript逆向知识体系(一)Babel、AST、ES6+、ES5、浏览器环境、Node.js环境的关系和处理流程

基础不牢&#xff0c;地动山摇&#xff0c;逆向越久&#xff0c;越发现基础的重要性&#xff0c;本系列&#xff0c;回顾js逆向基础&#xff0c;让自己的知识体系更加系统化。 以下是 Babel、AST、ES6、ES5、浏览器环境、Node.js环境 的关系和流程的详细说明及图表&#xff1a;…...

Oracle 数据库系统全面详解

Oracle 数据库是全球领先的关系型数据库管理系统(RDBMS)&#xff0c;由 Oracle 公司开发。它为企业级应用提供了高性能、高可用性、安全性和可扩展性的数据管理解决方案。 目录 一、Oracle 数据库体系结构 1. 物理存储结构 主要组件&#xff1a; 存储层次&#xff1a; 2. …...

LeetCode 解题思路 29(Hot 100)

解题思路&#xff1a; 映射关系建立&#xff1a;创建一个哈希表存储数字到字母的映射。递归参数&#xff1a; 给定字符串 digits、结果集 result、当前路径 path、当前位置 start。递归过程&#xff1a; 当当前位置 start 等于 digits 长度时&#xff0c;说明已经遍历完 digi…...

使用Python解析PPT文件并生成JSON结构详解

引言 PowerPoint&#xff08;PPT&#xff09;文件的自动化处理是办公自动化和数据提取的常见需求。本文将介绍如何通过Python的python-pptx库&#xff0c;将PPT文件的样式、结构、文本内容等信息解析为标准化的JSON格式&#xff0c;为后续的自动化处理、数据迁移或样式复用提供…...

LabVIEW永磁同步电机性能测试系统

开发了一种基于LabVIEW的永磁同步电机&#xff08;PMSM&#xff09;性能测试系统的设计及应用。该系统针对新能源汽车使用的电机进行稳态性能测试&#xff0c;解决了传统测试方法成本高、效率低的问题&#xff0c;实现了测试自动化&#xff0c;提高了数据的准确性和客观性。 ​…...

MTK Camera 照片切视频Systrace拆解分析

和你一起终身学习&#xff0c;这里是程序员Android 经典好文推荐&#xff0c;通过阅读本文&#xff0c;您将收获以下知识点: 一、Systrace 拆解概览二、Systrace 阶段拆解详解 一、Systrace 拆解概览 MTK Camera 照片切换视频trace 拆解(非切换摄像头类) 照片切换视频模块trace…...

某合约任意提取BNB漏洞

1背景描述 合约是一个在满足特定条件时在区块链上执行代码的程序&#xff0c;各方以数字签署合同的方式准许并维护它的其运行。这些代码可以是向朋友汇款、买卖 NFT 虚拟商品等一系列复杂的内容。 存在漏洞的目标合约是一个结合Meme文化病毒式传播与去中心化金融&#xff08;D…...

Linux_3.2

今天继续学习shell语法 shell类似一个面向过程的语言,要区分好面向过程和面向对象的语言的区别。 循环语句 for循环 for i in a 2 cc doecho $i done #输出a 2 ccfor file in `ls` doecho $file done #输出ls命令的输出for i in $(seq 1 10) doecho $i done #输出1-10,seq…...

插件实现:分别通过winform和WPF界面输入操作CAD——CAD c#二次开发

效果如下图所示&#xff1a; 主程序 using Autodesk.AutoCAD.ApplicationServices; using Autodesk.AutoCAD.DatabaseServices; using Autodesk.AutoCAD.EditorInput; using Autodesk.AutoCAD.Geometry; using Autodesk.AutoCAD.Runtime; using System; using System.Windows…...

【学Rust写CAD】20 平铺模式结构体(spread.rs)

这个 Spread。rs文件定义了渐变超出定义区域时的扩展方式&#xff0c;通常用于处理渐变在边界之外的行为。 源码 //color/spread.rs #[derive(Debug, Clone, Copy)] pub struct Pad; // 空结构体&#xff0c;表示 Pad 模式#[derive(Debug, Clone, Copy)] pub struct Reflect…...