数据结构(C语言):有序顺序表的设计及相关操作函数

news2025/1/11 7:42:23

一、题目

有序顺序表的设计

实验要求:

  • 有序顺序表的操作,包括初始化,求数据元素个数,插入,删除和取数据元素。放在头文件中(建议尝试用动态数组实现有序顺序表;注意有序顺序表的操作与课本上的操作有所不同,需要重写一些操作,如ListInsert(L,x),不需要参数i);
  • 设计合并函数ListMerge(L1,L2,L3),其功能是把有序表L1和L2中的数据合并到L3中,要求L3中的数据依然保持有序。(要求时间复杂度O(n), n= n1+n2,n1、n2分别为两个顺序表的长度);
  • 设计一个测试主函数实际验证所设计有序表的各项操作以及合并函数的正确性。

测试数据:

字符型或者整形:可选z,h,o,u, k,u,n,x,i,a,o(同学们自己名字的拼音)

二、算法思想

  1. 定义顺序表结构体:包括数组首元素的地址、顺序表当前长度。
  2. 顺序表初始化函数:在内存中开辟一段连续的内存空间用于后续储存顺序表的数据元素,将循序表当前长度赋值为0。
  3. 输入顺序表元素值的函数:连续输入n个数据元素并将其储存在数组中,并将顺序表表长赋值为n。
  4. 打印顺序表中的各数据元素的函数:利用循环打印数组元素。
  5. 求顺序表中数据元素个数的函数:直接返回顺序表的表长。
  6. 在第i个位置插入值为e的元素的函数:先判断初始条件是否成立:线性表不为空且插入位置合理,若不成立,则直接结束跳出函数。否则执行操作:从最后一个元素开始,依次用前驱元素覆盖后继元素,直到第i个元素为止,再用e给第i个元素赋值,顺序表长度自增一次。
  7. 删除第i个位置的元素的函数:先判断初始条件是否成立:线性表不为空且删除位置合理,若不成立,则直接结束跳出函数。否则执行操作:从第i个位置开始,依次用后继元素覆盖前驱元素,表长自减一次。
  8. 查找第i个元素并用e返回其值的函数:先判断初始条件是否成立:线性表不为空且查找位置合理,若不成立,则直接结束跳出函数。否则执行操作:将第i个元素的值赋值给e。
  9. 有序表合并的函数:建立新的顺序表储存合并后的顺序表,若两个顺序表均未插入完成,则将值小的元素插入新顺序表的表尾,再将较长的顺序表中未插入的元素插入新顺序表的表尾。
  10. 主函数:依次调用上述函数实现程序功能。

三、完整源代码

注:作者用的是多文件代码。

一、list.cpp

#include"list.h"

void InitList(List* L)//顺序表的初始化函数
{
	L->a = (ElemType*)malloc(sizeof(ElemType) * MAX_SIZE);
	L->length = 0;
}

void InputList(List* L,int n)//输入顺序表的元素值,n为待输入的元素个数
{
	printf("请输入%d个元素:", n);
	for (int i = 0; i < n; i++)
		scanf("%d", &L->a[i]);
	L->length = n;
}

void PrintList(List* L)//打印顺序表的各个元素
{
	for (int i = 0; i < L->length; i++)
		printf("%d ", L->a[i]);
}

int LengthList(List* L)//求数据元素个数的函数
{
	return L->length;//返回表长
}

Status InsertElem (List* L,int i,int e)//在第i个位置前插入值为e的元素
{
	if (L->length == 0 || i<1 || i>L->length)//初始条件:线性表不为空且插入位置合理
		return ERROR;
	int n = L->length;
	for (n; n >= i; n--)//从最后一个元素开始,依次用前驱元素覆盖后继元素
		L->a[n] = L->a[n - 1];
	L->a[n] = e;//用e给第i个元素赋值
	L->length++;//表长加1
	return OK;
}

Status DeleteElem(List* L,int i)//删除第i个位置的元素
{
	if (L->length == 0 || i<1 || i>L->length)//初始条件:线性表不为空且插入位置合理
		return ERROR;
	for (i; i < L->length; i++)//从第i个位置开始,依次用后继元素覆盖前驱元素
		L->a[i - 1] = L->a[i];
	L->length--;//表长减1
	return OK;
}

int SeekElem(List* L, int i,int* pe)//查找第i个位置的元素并用e返回其值
{
	if (L->length == 0 || i<1 || i>L->length)//初始条件:线性表不为空且查找位置合理
		return ERROR;
	*pe = L->a[i - 1];
	return OK;
}

List* ListMerge(List* L1, List* L2)//有序表合并函数
{
	List* L3 = (List*)malloc(sizeof(List));//建立新顺序表储存合并后的顺序表
	L3->a=(ElemType*)malloc(sizeof(ElemType) * MAX_SIZE * 2);
	L3->length = L1->length + L2->length;
	int i = 0,j = 0,k = 0;
	while (i < L1->length && j < L2->length)//两个顺序表均未插入完成
	{
		if (L1->a[i] >= L2->a[j])//将值小的元素插入新的顺序表末尾
		{
			L3->a[k] = L2->a[j];
			k++;
			j++;
		}
		else
		{
			L3->a[k] = L1->a[i];
			k++;
			i++;
		}
	}
	if(i==L1->length)//L1已插入完成,而L2还未完成
		for (j; j < L2->length; j++)//将L2中剩余元素插入新顺序表末尾
		{
			L3->a[k] = L2->a[j];
			k++;
			j++;
		}
	else//L2已插入完成,而L1还未完成
		for (i; i < L1->length; i++)//将L1中剩余元素插入新顺序表末尾
		{
			L3->a[k] = L1->a[i];
			k++;
			i++;
		}
	return L3;//返回新顺序表
}

二、list.h

#pragma once

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>

typedef int ElemType;
typedef int Status;
#define MAX_SIZE 10//允许存储的最大元素数量
#define ERROR 0
#define OK 1

typedef struct List {
	ElemType* a;
	int length;//顺序表表长
};

void InitList(List* L);//顺序表的初始化函数
void InputList(List* L, int n);//输入顺序表的元素值,n为待输入的元素个数
void PrintList(List* L);//打印顺序表的各个元素
int LengthList(List* L);//求数据元素个数的函数
Status InsertElem(List* L, int i, int e);//在第i个位置插入值为e的元素
Status DeleteElem(List* L, int i);//删除第i个位置的元素
int SeekElem(List* L, int i, int* e);//查找第i个位置的元素并用e返回其值
List* ListMerge(List* L1, List* L2);//有序表合并函数

三、main.cpp

#include"list.h"

int main()
{
	List* L1 = (List*)malloc(sizeof(List));
	List* L2 = (List*)malloc(sizeof(List));
	InitList(L1);
	InitList(L2);
	int n1;
	printf("请输入第一个顺序表的元素个数:");
	scanf("%d", &n1);
	InputList(L1, n1);
	int n2;
	printf("请输入第二个顺序表的元素个数:");
	scanf("%d", &n2);
	InputList(L2, n2);
	printf("顺序表L1中的元素个数为:%d\n", LengthList(L1));
	printf("顺序表L1中的元素个数为:%d\n", LengthList(L2));
	int i1, e1;
	printf("请输入待插入元素的位置和待插入元素的值:");
	scanf("%d %d", &i1, &e1);
	if(!InsertElem(L1, i1, e1))
		printf("插入元素失败!");
	printf("插入元素后的顺序表L1为:");
	PrintList(L1);
	printf("\n");
	int i2;
	printf("请输入待删除元素的位置:");
	scanf("%d", &i2);
	if (!DeleteElem(L2, i2))
		printf("删除元素失败!");
	printf("删除元素后的顺序表L2为:");
	PrintList(L2);
	printf("\n");
	int i;
	printf("请输入L1中待查找的元素位置:");
	scanf("%d", &i);
	int e;
	int* pe = &e;
	if (!SeekElem(L1, i, pe))
		printf("查找元素失败!");
	else
		printf("L1中第%d个元素的值为:%d", i, e);
	printf("\n");
	printf("L1和L2合并后的有序表为:");
	PrintList(ListMerge(L1, L2));
	return 0;
}

四、运行结果

 

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

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

相关文章

【正点原子STM32连载】 第十七章 串口通信实验摘自【正点原子】STM32F103 战舰开发指南V1.2

1&#xff09;实验平台&#xff1a;正点原子stm32f103战舰开发板V4 2&#xff09;平台购买地址&#xff1a;https://detail.tmall.com/item.htm?id609294757420 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/thread-340252-1-1.html 第十七…

2023年25个Java8面试问题和答案

Java是一种非常流行的编程语言&#xff0c;从Android应用程序到物联网&#xff08;IoT&#xff09;无处不在。事实上&#xff0c;根据Codeplatoon的数据&#xff0c;Java在1年的招聘信息中排名#2022。考虑到它的普遍存在&#xff0c;对精通Java的专业人员的需求仍然很高也就不足…

【vlan高级特性——super vlan概述】

今天给大家分享Windows常用cmd网络命令&#xff0c;希望对大家能有所帮助&#xff01; 1、arp [option] [address] 显示/修改ARP缓存 执行命令&#xff1a;arp -a 参数说明&#xff1a; 显示和修改地址解析协议(ARP)使用的“IP 到物理”地址转换表。 ARP -s inet_addr eth…

那些30多岁的测试工程师都是怎么走过来的?

最近工作真的不好找了&#xff0c;感觉身边的朋友明显变得焦虑了&#xff0c;一个个都在抱怨生活的迷茫和疑惑。 30岁测试员该何去何从&#xff1f; 如今我们往往能够看到网上的各种新闻&#xff0c;什么“30岁是程序员的一道坎“ “非诚勿扰:32岁 程序员登台&#xff0c;遭美…

【Java-Crawler】爬取动态页面(WebMagic、Selenium、ChromeDriver)

WebMagicSeleniumChromeDriverMaven 爬取动态页面 一、需要下载的资源和引入的依赖资源依赖 二、实战代码测试效果 在上一篇说WebMagic框架的时候&#xff08; 一文学会WebMagic爬虫框架&#xff09;&#xff0c;提到了WebMagic仅能解析静态页面&#xff0c;满足不了小编的爬虫…

chatgpt赋能Python-python_numpy转置

Python中的Numpy转置&#xff1a;使用transpose()函数 在Python中&#xff0c;Numpy是非常常用的一个科学计算库&#xff0c;它提供了大量的数学函数、矩阵计算等功能。其中&#xff0c;矩阵的转置是一个非常基本的运算&#xff0c;在Numpy中&#xff0c;我们可以使用transpos…

SSRS rdlc报表 六 报表分组和总计

报表分组和总计在报表中是一个很常用的功能&#xff0c;比如我们需要按部门进行分组&#xff0c;统计每个部门的费用支出&#xff0c;或者在进一步分组&#xff0c;每个部门每个月的费用支出&#xff0c;通过rdlc报表&#xff0c;很容易实现这个需求。 我们下面要讲解的案例&a…

Thinkphp漏洞详解合集

文章目录 Thinkphp6.0.12LTS反序列化漏洞环境漏洞分析 thinkphp lang命令执行环境影响版本漏洞分析漏洞复现 CNVD-2018-24942(t5RCE)环境影响版本漏洞分析漏洞复现 Thinkphp3.2.x命令执行环境漏洞分析漏洞复现 thinkphp-2x-rce漏洞环境影响版本漏洞分析 Thinkphp5.0.23变量覆盖…

人机交互软件工程视角 第3-11章部分课后习题答案

4. 对于用于帮助儿童之间进行交流和合作的移动设备&#xff0c; 核心可用性目标&#xff1a; 简单易用性&#xff1a;移动设备应该具备简单直观的界面和操作方式&#xff0c;以便儿童能够轻松理解和使用。 可靠性&#xff1a;设备应该稳定运行&#xff0c;并且提供可靠的通…

什么是智能制造?制造企业该如何发展?

智能制造是落实我国制造强国战略的重要举措&#xff0c;加快推进智能制造&#xff0c;是加速我国工业化和信息化深度融合、推动制造业供给侧结构性改革的重要着力点&#xff0c;对重塑我国制造业竞争新优势具有重要意义。 ——摘自《中国制造 2025》 概念的提出 德勤公司(Delo…

使用 PAI-Blade 优化 Stable Diffusion 推理流程(二)

背景 上一篇中&#xff0c;我们使用了 PAI-Blade 优化了 diffusers 中 Stable Diffusion 模型。本篇&#xff0c;我们继续介绍使用 PAI-Blade 优化 LoRA 和 Controlnet 的推理流程。相关优化已经同样在 registry.cn-beijing.aliyuncs.com/blade_demo/blade_diffusion镜像中可以…

Linkage Mapper 连通性模型的构建方法详解(含实际案例分析)

✅创作者:陈书予 🎉个人主页:陈书予的个人主页 🍁陈书予的个人社区,欢迎你的加入: 陈书予的社区 🌟专栏地址: Linkage Mapper解密数字世界链接 文章目录 一、 简介1.1 连通性模型概述二、 Linkage Mapper工具箱2.1 工具箱概述2.2 安装和加载工具箱

【Android定制】BUILD_AGO_GMS = no 和 BUILD_GMS=no属性

文章目录 概要名词解释细节小结 概要 在安卓底层源码中&#xff0c;有这样的两个属性&#xff0c;这两个第一眼看上去都像是带不带谷歌&#xff0c;BUILD_AGO_GMS no和BUILD_GMSno有什么区别&#xff1f;&#xff1f; 如果带了谷歌&#xff0c;那么这个设备就差不多是国外定…

低代码平台盘点:这5款平台备受欢迎!

随着数字化转型需求的持续增长&#xff0c;企业正在寻求更高效的方式来构建定制软件。低代码平台因其能够以最少的编码需求促进更快的应用程序开发而广受欢迎。这些平台提供拖放界面、预置模板和可视化设计工具&#xff0c;使用户无需具备编程语言专业知识即可构建自定义应用程…

超详细的React路由基础使用

目录 基础路由 结构准备 封装自定义NavLink 路由的模糊匹配 嵌套路由 路由传参 声明式路由 路由传递params参数 search(也称query)参数 state传参 编程式路由导航 withRouter 演示 基础路由 单页应用程序 SPA: 整个应用只有一个完整的页面 点击页面中的链接不会刷新…

API架构的选择,RESTful、GraphQL还是gRPC

文章目录 一、RESTful1、什么是RESTful&#xff1f;2、RESTful架构的原则3、RESTful的适用场景4、RESTful的优点5、RESTful的缺点 二、GraphQL1、什么是GraphQL&#xff1f;2、GraphQL的原则3、GraphQL的优点4、GraphQL的缺点 三、gRPC1、什么是gRPC2、gRPC的应用场景3、gRPC的…

SpringBoot打包轻身方法

前言: 记得有人说过,Sb(ps:简称:SpringBoot)可以采用镜像分离进行部署打包,但是这种的话需要docker环境,由于Docker不会使用,还会在Centenos中出现各种错误,无法解决.个人菜 纯属个人意见,本次不会采用Docker 进而采用maven的插件进行打包. 1,在pom文件中加入配置以下: <bu…

队列的实现(附含三道经典例题)

&#x1f349;文章主页&#xff1a;阿博历练记 &#x1f4d6;文章专栏&#xff1a;数据结构与算法 &#x1f68d;代码仓库&#xff1a;阿博编程日记 &#x1f365;欢迎关注&#xff1a;欢迎友友们点赞收藏关注哦&#x1f339; 文章目录 &#x1f33e;前言&#x1f3ac;队列&…

HACK ME PLEASE: 1

文章目录 HACK ME PLEASE: 1实战演练一、前期准备1、相关信息 二、信息收集1、访问网站2、端口扫描2、扫描目录3、访问网站4、访问网站5、扫描目录6、访问网站7、登录MySQL数据库8、查看数据表9、查看users表的内容10、查看tblUsers表内容11、解密12、加密13、修改密码14、查询…

解决Ubuntu 22.04 程序以管理员权限运行无法播放声音

文章目录 摘要需求背景问百度问GPT最终解决方案,这篇文章的核心第一步,把root账户加入到组里面,第二步,编写一个服务文件第三步,允许这个文件第四步,启动服务第五步,修改Config文件第六步,重启电脑关键字: Qt、 pulseaudio、 管理员、 声音、 服务 摘要 这个是我…