【数据结构】线性表的顺序存储结构及实现——C语言版

这篇具有很好参考价值的文章主要介绍了【数据结构】线性表的顺序存储结构及实现——C语言版。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

假设线性表采取顺序存储结构,写出以下算法并用c语言实现。 (1)定义线性表的数据结,每日进步一点点,数据结构,c语言,算法
假设线性表采取顺序存储结构,写出以下算法并用c语言实现。 (1)定义线性表的数据结,每日进步一点点,数据结构,c语言,算法


假设线性表采取顺序存储结构,写出以下算法并用c语言实现。 (1)定义线性表的数据结,每日进步一点点,数据结构,c语言,算法

顺序表

线性表的顺序存储结构称为顺序表,其基本思想是用一段地址连续的存储单元一次存储线性表的数据元素。

设顺序表的每个元素占用 c 个存储单元,则第 i 个元素的存储地址为:

假设线性表采取顺序存储结构,写出以下算法并用c语言实现。 (1)定义线性表的数据结,每日进步一点点,数据结构,c语言,算法

所以,只要确定了存储顺序表的起始地址(即基地址),计算任意一个元素的存储地址的时间是相等的。

我们通常用一维数组来实现顺序表,也就是把线性表中相邻的元素存储在数组中相邻的位置,从而导致数据元素的序号和存放它的数组下标之间具有一一对应的关系。

注意: \color{RoyalBlue}注意: 注意:
C语言中数组的下标是 从0开始 的,而顺序表中元素的序号是 从1开始 的,即线性表中第 i 个元素存储在数组中下标为 i-1 的位置。

定义一个数组必须确定数组的长度。由于线性表中可以进行插入操作,所以数组长度要大于当前线性表的长度。MaxSize表示数组长度,用length表示线性表的长度。

假设线性表采取顺序存储结构,写出以下算法并用c语言实现。 (1)定义线性表的数据结,每日进步一点点,数据结构,c语言,算法

假设线性表采取顺序存储结构,写出以下算法并用c语言实现。 (1)定义线性表的数据结,每日进步一点点,数据结构,c语言,算法

1. 顺序表的存储结构定义

#define MaxSize 100  //假设顺序表最多存放100个元素
typedef int DataType;	//定义线性表的数据类型,假设为int型

typedef struct
{
	DataType data[MaxSize];	//存放数据元素的数组
	int length;	//线性表的长度
}SeqList;

假设线性表采取顺序存储结构,写出以下算法并用c语言实现。 (1)定义线性表的数据结,每日进步一点点,数据结构,c语言,算法

2. 顺序表的实现

2.1 初始化顺序表

初始化顺序表只需要将顺序表的长度length初始化为0,

void InitList(SeqList* L)
{
	L->length = 0;
}

2.2 建立顺序表

建立一个长度为n的顺序表,需要将给定的数据元素传入顺序表中,并将传入的元素个数作为顺序表的长度。

设给定的数据元素存放在数组a[n]中,建立顺序表的操作如图:

假设线性表采取顺序存储结构,写出以下算法并用c语言实现。 (1)定义线性表的数据结,每日进步一点点,数据结构,c语言,算法

函数CreatList的返回值表示建立顺序表操作是否成功,如果顺序表的存储空间小于给定数据元素个数,则无法建立顺序表。

int CreatList(SeqList* L, DataType a[], int n)
{
	if (n > MaxSize)
	{
		printf("顺序表的存储空间不够,无法建立顺序表\n");
		return 0;
	}
	for (int i = 0; i < n; i++)
	{
		L->data[i] = a[i];
	}
	L->length = n;
	return 1;
}

2.3 销毁顺序表

顺序表是静态存储分配,在顺序表变量退出作用域时,自动释放该变量所占内存单元。因此,顺序表无须销毁。

2.4 判空操作

顺序表的判空操作只需要判断长度length是否为0就可以了,

int Empty(SeqList* L)
{
	if (L->length == 0) {
		return 1;	//顺序表为空返回1
	}
	else
	{
		return 0;
	}
}

2.5 求顺序表的长度

int Length(SeqList* L)
{
	return L->length;
}

2.6 遍历操作

在顺序表中,遍历操作即是按下标依次输出各元素

void PrintList(SeqList* L)
{
	for (int i = 0; i < L->length; i++)
	{
		printf("%d ", L->data[i]);	//输出线性表的元素值,假设为int型
	}
}

2.7 按值查找

在顺序表中实现按值查找操作,需要对顺序表中的元素依次进行比较,如果查找成功,返回元素的序号(注意不是下标),否则返回0

int Locate(SeqList* L, DataType x)
{
	for (int i = 0; i < L->length; i++)
	{
		if (L->data[i] == x)
		{
			return i + 1;	//返回序号
		}
	}
	return 0;	//循环结束,说明查找失败
}

2.8 按位查找

顺序表中第i个元素存储在数组中下标为i-1的位置,
所以,很容易实现按位查找。

函数Get的返回值表示是否查找成功,若查找成功,通过指针参数ptr返回查找到的元素值。

int Get(SeqList* L, int i, DataType* ptr)
{
	if (i<1 || i>L->length)
	{
		printf("查找位置非法,查找失败\n");
		return 0;
	}
	else
	{
		*ptr = L->data[i - 1];
		return 1;
	}
}

2.9 插入操作

插入操作是在表的第i(1≦i≦n+1)个位置进行插入新元素x,使长度为n的线性表变成了长度为n+1的线性表。

假设线性表采取顺序存储结构,写出以下算法并用c语言实现。 (1)定义线性表的数据结,每日进步一点点,数据结构,c语言,算法

注意: \color{RoyalBlue}注意: 注意:
元素移动的方向,是从最后一个元素开始移动,直至将第i个元素后移为止,然后将新元素插入i处。如果表满,则引发上溢错误,如果元素的插入位置不合法,则引发位置错误。

int Insert(SeqList* L, int i, DataType x)
{
	if (L->length >= MaxSize)
	{
		printf("上溢错误,插入失败");
		return 0;
	}
	if (i<1 || i>L->length + 1)
	{
		printf("位置错误,插入失败");
		return 0;
	}
	for (int j = L->length; j >= i; j--)
	{
		L->data[j] = L->data[j - 1];
	}
	L->data[i - 1] = x;
	L->length++;
	return 1;
}

2.10 删除操作

删除操作是将表的第i(1≦i≦n)个元素删除,使长度为n的线性表变成了长度为n-1的线性表。

假设线性表采取顺序存储结构,写出以下算法并用c语言实现。 (1)定义线性表的数据结,每日进步一点点,数据结构,c语言,算法

注意: \color{RoyalBlue}注意: 注意:
元素移动的方向,是从第 i+1 个元素(下标为i)开始移动,直至将最后一个元素前移为止,并且在移动元素之前取出被删元素。如果表空,则引发下溢错误,如果元素的删除位置不合理,则引发位置错误。

int Delete(SeqList* L, int i, DataType* ptr)
{
	if (L->length == 0)
	{
		printf("下溢错误,删除失败\n");
		return 0;
	}
	if (i<1 || i>L->length)
	{
		printf("位置错误,删除失败\n");
		return 0;
	}
	*ptr = L->data[i - 1];	//取出位置i的元素
	for (int j = i ; j < L->length; j++)
	{
		L->data[j - 1] = L->data[j];
	}
	L->length--;
	return 1;
}

假设线性表采取顺序存储结构,写出以下算法并用c语言实现。 (1)定义线性表的数据结,每日进步一点点,数据结构,c语言,算法

3. 顺序表的使用

#include<stdio.h>
#include<stdlib.h>
/*将顺序表的存储结构定义和各个函数定义放到这里*/

int main()
{
	int r[5] = { 1,2,3,4,5 }, i, x;
	SeqList L;	//定义变量L为顺序表类型
	CreatList(&L, r, 5);	//建立具有5个元素的顺序表
	printf("当前线性表的数据为:");
	PrintList(&L);	//输出当前线性表 1 2 3 4 5
	Insert(&L, 2, 8);	//在第2个位置插入值为8的元素
	printf("插入之后的数据为:");
	PrintList(&L);	//输出插入后的线性表 1 8 2 3 4 5
	printf("当前线性表的长度为:%d\n", Length(&L));	//输出线性表的长度6
	printf("请输入查找的元素值:");
	scanf("%d", &x);
	i = Locate(&L, x);
	if (i == 0)
	{
		printf("查找失败\n");
	}
	else
	{
		printf("元素%d的位置为:%d\n", x, i);
	}
	printf("请输入查找第几个元素的值:");
	scanf("%d", &i);
	if (Get(&L, i, &x) == 1)
	{
		printf("第%d个元素的值为:%d\n", i, x);
	}
	else
	{
		printf("线性表中没有第%d个位置元素\n",i);
	}
	printf("请输入要删除第几个元素:");
	scanf("%d", &i);
	if (Delete(&L, i, &x) == 1)
	{
		printf("删除成功,删除的数据为%d\n", x);
	}
	else
	{
		printf("删除操作失败\n");
	}
	return 0;
}

假设线性表采取顺序存储结构,写出以下算法并用c语言实现。 (1)定义线性表的数据结,每日进步一点点,数据结构,c语言,算法

4. 暖暖树洞

“要留点精力去读书去运动去爱人,去奔赴想要的生活,不应该把精力浪费在痛苦的社交讨厌的人那里,看起来可以挽回的事情,仔细想想一点都不值得,贪恋过去的快乐注定走不远,过去的就让它过去吧,在热爱生活的同时快乐的小事情真的很多很多。”文章来源地址https://www.toymoban.com/news/detail-840305.html

到了这里,关于【数据结构】线性表的顺序存储结构及实现——C语言版的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构:线性表————顺序表的实现、项目和OJ题目(手把手教你写代码)

    🌈 个人主页: 小新_- 🎈个人座右铭:“成功者不是从不失败的人,而是从不放弃的人!”🎈 🎁欢迎各位→点赞👍 + 收藏⭐️ + 留言📝 🏆所属专栏:  话说那些与C++的爱恨情仇   欢迎订阅,持续更新中~~~                                           ✨让小新带着你

    2024年04月16日
    浏览(109)
  • 【玩转408数据结构】线性表——线性表的顺序表示(顺序表)

            通过前文,我们了解到线性表是具有相同数据类型的有限个数据元素序列;并且,线性表只是一种逻辑结构,其不同存储形式所展现出的也略有不同,那么今天我们来了解一下线性表的顺序存储——顺序表。         顺序表指的是将 逻辑上相邻的元素 存储在 物理位

    2024年02月19日
    浏览(52)
  • 数据结构:线性表顺序存储结构———顺序表

    目录 顺序表的定义 初始化线性表 销毁线性表 求线性表的长度 判断是否为空表 插入数据元素 逻辑序号与物理序号的区别 删除数据元素 输出线性表  按序号求线性表中的元素 按元素值查找 整体上创建顺序表 顺序表实验 线性表的顺序存储是把线性表中的所有元素按照其逻辑

    2024年02月03日
    浏览(46)
  • 【数据结构与算法】二、线性表的顺序表示【硬核】

    图书表的顺序存储结构类型定义: 在调用函数的过程中,当形参为引用类型时,实参和形参占用了相同的空间 2.4.1 线性表的基本操作: 2.4.2 线性表L的初始化 2.4.3 销毁和清空线性表L 2.4.4 求线性表L的长度以及判断线性表L是否为空 2.4.5 顺序表的取值(根据位置i获取相应位置

    2023年04月26日
    浏览(53)
  • 【数据结构】(顺序表)C语言实现线性表顺序存储的创建、插入、删除、查找、输出等基本操作(附完整代码)

    要求:利用书本上的线性表的顺序存储结构定义 #define MAXSIZE 100 //顺序表可能达到的最大长度 typedef struct{ ElemType *elem; // 存储空间基址 int length; // 当前长度 int listsize; // 当前分配的存储容量(以sizeof(ElemType)为单位) } SqList; 1)编写完成下列功能的函数: (1)初始化一个线性表

    2024年04月28日
    浏览(48)
  • 数据结构(王道)——线性表的存储结构之循环表

      创建并初始化、判断循环单链表是否为空、判断结点p是否为循环单链表的表尾结点的代码操作。           创建并初始化、判断循环双链表是否为空、判断结点p是否为循环双链表的表尾结点的代码操作。     普通双链表用以下代码实现插入的时候,如果插入的结点是最后

    2024年02月16日
    浏览(39)
  • C/C++数据结构---顺序表---线性存储结构

    个人主页: 仍有未知等待探索_小项目,洛谷刷题,数据结构-CSDN博客 专题分栏---数据结构: 数据结构_仍有未知等待探索的博客-CSDN博客 目录 一、知识储备 二、引例  三、顺序表 第一步,先创建一个顺序表类型 第二步,定义和初始化顺序表    第三步,顺序表的基本操作

    2024年02月08日
    浏览(42)
  • 数据结构 线性表的定义和基本操作(以顺序表为例)

    名人说:一花独放不是春,百花齐放花满园。——《增广贤文》 作者:Code_流苏(CSDN) (一个喜欢古诗词和编程的Coder😊) 以下代码个人分享出来,仅供学习交流,且仅在CSDN平台发布,未经授权禁止二次转发。 〇、线性表是什么? 1、定义 线性表 是具有 相同数据类型 的 n(

    2024年02月12日
    浏览(63)
  • 【数据结构】线性表(一)线性表的定义及其基本操作(顺序表插入、删除、查找、修改)

    目录 一、线性表 1. 线性表的定义 2. 线性表的要素 二、线性表的基本操作 三、线性表的顺序存储结构 1. 定义 2. 顺序表的操作       a. 插入操作 b. 删除操作 c. 查找操作 d. 修改操作 e. 代码实例          一个线性表是由零个或多个 具有相同类型的结点 组成的有序集合。

    2024年02月03日
    浏览(69)
  • 数据结构(王道)——线性表之静态链表&顺序表和链表的比较

      如何定义一个静态链表     初始化静态链表:   静态链表的查找、插入、删除           创: 销:   增、删:   查:   顺序表、链表该如何选择?  

    2024年02月16日
    浏览(126)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包