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

news2025/4/2 21:05:47

这里写自定义目录标题

  • 一、实验目的
  • 二、注意事项
  • 三、实验内容
    • (一)问题描述
    • (二)基本要求
  • 四,操作步骤
    • (一)使用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");
        else
            printf("  有符合条件的元素,位置为:%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.按照需求,调试程序。
在这里插入图片描述

在这里插入图片描述

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

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

相关文章

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

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

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

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

【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官方文档…

【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…

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;有一种便捷的方法…

LVGL Dropdown和Calendar详解

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

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模式访问这些网站。 以下是两种…

LeetCode 解题思路 29(Hot 100)

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

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…

插件实现:分别通过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…

白酒迈入3.0时代,珍酒李渡如何穿越周期高质增长?

当下&#xff0c;白酒行业仍处深度调整期&#xff0c;过往通过渠道拓展、硬广宣传等推动规模扩张、提升市场份额的模式&#xff0c;愈发难以为继。 行业迫切需要构建高质增长新模式&#xff0c;完成增长动能转换。中国酒业协会理事长宋书玉提出&#xff0c;白酒消费亟需进入品…

人工智能-LangGraph+ChatUI+DeepSeek API搭建本地智能助手

人工智能-LangGraphChatUIDeepSeek API搭建本地智能助手 0 环境说明1 LangGraph2 Agent Chat UI 0 环境说明 环境项环境说明操作系统Windows11 专业版硬件信息联想拯救者Y9000PcondaAnancondaPython版本3.12NodeJs18.20.0 # 使用conda创建python环境 conda create -n langgra…