数据结构之线性表(1)

news2024/12/24 8:42:45

数据结构之线性表

1.线性表的定义

线性表是一种线性结构。在一个线性表中数据元素的类型是相同的,或者说线性表是由同一类型的数据元素构成的线性结构。
线性表是具有相同数据类型的n(n>=0)个数据元素的有限序列。
n表示表长,当n=0时称该线性表为空表。

2.线性表的存储方式

线性表的存储方式有顺序存储链式存储两种

1.顺序存储:

在内存中用连续的一块存储空间顺序存放线性表中的各数据元素。
优点:内存中的地址空间是线性的,物理位置关系上的实现数据元素之间的逻辑相邻关系简单自然。
缺点:当不确定存储多少数据时,内存开辟了之后,多了造成浪费,少了不够用,其次,数据中的元素增删查改时间复杂度过高。

2.链式存储:

在内存中以链表的形式存储,内存中的地址不连续。
优点:可以根据需要来申请内存空间,方便灵活。
缺点:物理位置关系上不能反映数据元素之间的逻辑。为指针开辟一个空间,会有多余的内存损耗。

3.顺序表的存储

顺序表的存储方式有两种:
1.静态顺序表
2.动态顺序表
今天我们来详细了解静态顺序表的相关操作
顺序表的静态存储就是在存放数据时,已经给定了存储空间的大小。
其结构体的声明为:

typedef struct
{
	datatype data[MAXSIZE];//MAXSIZE为元素的最大存储个数
	int last;//last起到一个指针的作用,始终指向线性表中的最后一个元素,当表空时,last==-1
}SeqList;
//定义一个顺序表
SeqList  L;

在这里插入图片描述
其中表长=L.last+1,线性表中的数据元素a1~an分别存放在L.data[0]-L.data[L.last]中

4.顺序表的基本操作实现

我们学会了顺序表的基本语法,我们现在可以对线性表进行简单的操作。
以下为顺序表的静态存储的相关操作:

4.1顺序表的初始化

//顺序表的初始化
Seqlist* init_SeqList()
{
	Seqlist* L;
	L = malloc(sizeof(Seqlist));
	L->last = -1;
	return L;
}

4.2顺序表的插入

//顺序表的插入
int insert_SeqList(Seqlist* L,int i, datatype x)
{
	if (L->last == MAXSIZE - 1)
	{
		printf("表满\n");
		return (-1);
	}
	if (i<1 || i>L->last - 2)
	{
		printf("插入位置错误\n");
		return 0;
	}
	int j = 0;
	for (int j = L->last; j > i; j--)
	{
		L->data[j + 1] = L->data[j];
	}
	L->data[j] = x;
	L->last++;
	return (1);
}

4.3顺序表的删除

//顺序表的删除
void  Deleate_SeqList (Seqlist* L, int i)
{
	int j;
	if (i<1||i>L->last +1)
	{
		printf("不存在第i个元素\n");
	}
	for (j = i + 1; j < L->last; j++)
	{
		L->data[j - 1] = L->data[j];
	}
	L->last--;
}

4.4顺序表的按值查找

//顺序表的查找
void  Deleate_SeqList(Seqlist* L, datatype x)
{
	int i = 0;
	int flag = 0;
	for (i = 0; i < L->last; ++i)
	{
		if (L->data[i] == x)
		{
			flag = 1;
			printf("查找的元素在第%d个位置上\n", i);
			break;
		}
	}
	if (flag == 0)
	{
		printf("查找的该元素不存在\n");
	}
}

4.5顺序表中值的修改

//顺序表中值的修改
void Change_SeqList(Seqlist* L,int i,datatype x)
{
	if (i<1 || i>L->last + 1)
	{
		printf("修改位置错误\n");
	}
	for (int j = 0; j < i; j++)
	{
		L->data[i] = x;
	}
}

以上就是对顺序表静态存储中的增删查改的相关操作了,下文继续创作动态存储下顺序表的相关操作,谢谢大家支持!

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

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

相关文章

java版多语言抢单系统 多语言海外AEON抢单可连单加额外单源码 抢单平台搭建开发 抢单开挂的软件

此套是全新开发的java版多语言抢单系统。 后端java&#xff0c;用的若依框架&#xff0c;这套代码前后端是编译后的&#xff0c;测试可以正常使用&#xff0c;语言繁体&#xff0c;英文&#xff0c;日语 源码大小&#xff1a;155M 源码下载&#xff1a;https://download.csd…

QT系列教程(10) QTextEdit学习

简介 QTextEdit是文本编辑器&#xff0c;支持富文本功能。接下来我们创建一个Qt Application 应用&#xff0c;然后在ui中添加一个QTextEdit插件。 运行程序后&#xff0c;可以在QTextEdit中输入任何文字也包括富文本。 文本块 我们在MainWindow的ui文件中添加了textedit插件…

iOS--block再学习

block再学习 什么是blockblock是带有自动变量的匿名函数block语法 block的实现block的实质截获自动变量__blcok说明符Block存储域__block变量存储域使用__block变量用结构体成员变量__forwarding的原因 截获对象 什么是block Block时c语言的扩充功能&#xff0c;它允许开发者定…

图像处理方向信息

前言 Exif 规范 定义了方向标签&#xff0c;用于指示相机相对于所捕获场景的方向。相机可以使用该标签通过方向传感器自动指示方向&#xff0c;也可以让用户通过菜单开关手动指示方向&#xff0c;而无需实际转换图像数据本身。 在图像处理过程中&#xff0c;若是原图文件包含…

中间件学习-RocketMQ-从零到一学习-2RocketMQ 的工作原理

中间件学习-RocketMQ-从零到一学习-2RocketMQ 的工作原理 RocketMQ 工作原理 1. 启动 NameServer 启动 NameServer。NameServer 启动后监听端口&#xff0c;等待 Broker、Producer、Consumer 连接&#xff0c;相当于一个路由控制中心。 2. 启动 Broker 启动 Broker。与所有…

ansible.cfg forks参数

在Ansible的配置文件ansible.cfg中&#xff0c;forks参数是一个非常关键的设置&#xff0c;它控制了Ansible执行任务时的并发连接数&#xff0c;直接影响到Ansible执行 playbook 或 ad-hoc 命令时的速度和效率。 意义与作用 并发控制&#xff1a;当你使用Ansible来管理多台主…

VRRP基础配置(华为)

#交换设备 VRRP基础配置 VRRP (Virtual Router Redundancy Protocol) 全称是虚拟路由规元余协议&#xff0c;它是一种容错协议。该协议通过把几台路由设备联合组成一台虚拟的路由设备&#xff0c;该虚拟路由器在本地局域网拥有唯一的一个虚拟 ID 和虚拟 IP 地址。实际上&…

计算机毕业设计python+spark知识图谱音乐推荐系统 音乐数据分析可视化大屏 音乐爬虫 LSTM情感分析 大数据毕设 深度学习 机器学习

流程&#xff1a; 1.Python采集网易云音乐歌手、歌词、音乐、评论等约10-20万海量数据&#xff0c;存入mysql数据库&#xff1b; 2.使用pandasnumpy/MapReduce对mysql中四类数据进行数据清洗&#xff0c;写入.csv文件并上传至hdfs(含评论NLP文本分类/lsm情感分析); 3.使用hive建…

LVGL移植和图片显示

最近闲来无事&#xff0c;偶尔刷到了移植LVGL的教程&#xff0c;今天肝完了机械原理又移植完LVGL库&#xff0c;真是收获满满的一天&#xff0c;先接一杯水去。 回来了&#xff0c;发个朋友圈高级一下&#xff0c;好困。 lvgl v8.3移植及组件使用_lvgl界面编辑器-CSDN博客htt…

nlp学习笔记

目录 很多入门例子 bert chinese 很多入门例子 https://github.com/lansinuote/Huggingface_Toturials bert chinese import torch import torch.nn as nn from transformers import AutoTokenizer, AutoModel, BertModel, TFBertModel, BertTokenizer# youpath = D:/bert-…

任务调度选择之PowerJob 和 Snail Job

背景 最近在选择一款任务调度产品&#xff0c;找了几款产品进行调研&#xff0c;我对产品的要求是可以进行可视化、有角色权限、任务编排、支持http、接入成本低等&#xff0c;发现有有两款挺符合的PowerJob和Snail Job。 同类产品对比 Elastic-Jobxxl-jobPowerJobSnail Job…

c#自定义ORM框架-实体类扩展属性

步骤一、建立扩展属性类 实体类扩展属性要继承Attribute基类完成 步骤二、创建实体类并引用扩展实体类属性 Attributes属性定义&#xff0c;主要标明表名和主键名字 /// <summary> /// 表名 /// </summary> [AttributeUsage(AttributeTargets.Class)] [System.S…

C语言之存储类、作用域、生命周期、链接属性

一 &#xff1a;概念解析 1&#xff1a; 存储类 &#xff08;1&#xff09;存储类就是存储类型&#xff0c;就是描述C语言变量存储在什么地方 &#xff08;2&#xff09;内存有多种管理方法&#xff1a;栈、堆数据段、bss段、.text段......一个变量的存储类属性就是描述…

Objective-C之通过协议提供匿名对象

概述 通过协议提供匿名对象的设计模式&#xff0c;遵循了面向对象设计的多项重要原则&#xff1a; 接口隔离原则&#xff1a;通过定义细粒度的协议来避免实现庞大的接口。依赖倒置原则&#xff1a;高层模块依赖于抽象协议&#xff0c;而不是具体实现。里氏替换原则&#xff1…

计算机毕业设计 | SpringBoot+vue的教务管理系统

1&#xff0c;绪论 1.1 项目背景 在这个资讯高度发展的时代&#xff0c;资讯管理变革已经是一个更为宽泛、更为全面的潮流。为了保证中国的可持续发展&#xff0c;随着信息化技术的不断进步&#xff0c;教务管理体系也在不断完善。与此同时&#xff0c;伴随着信息化的飞速发展…

Golang-分离式加载器(传参)AES加密

目录 enc.go 生成: dec.go --执行dec.go...--上线 cs生成个c语言的shellcode. enc.go go run .\enc.go shellcode 生成: --key为公钥. --code为AES加密后的数据, ----此脚本每次运行key和code都会变化. package mainimport ("bytes""crypto/aes"&…

好书推荐之《生成式 AI 入门与亚马逊云科技AWS实战》

最近小李哥在亚马逊云科技峰会领到了一本关于如何在云计算平台上设计、开发GenAI应用的书&#xff0c;名字叫&#xff1a;《生成式 AI 入门与亚马逊云科技AWS实战》&#xff0c;今天仔细看了下&#xff0c;发现这本书讲的真的很好&#xff01;他涵盖了当下AI领域所有热门的技术…

《精通ChatGPT:从入门到大师的Prompt指南》第11章:Prompt与AI的未来

第11章&#xff1a;Prompt与AI的未来 11.1 技术发展的新方向 在迅速发展的人工智能领域&#xff0c;Prompt工程作为与AI模型交互的核心方式&#xff0c;正处于技术创新的前沿。未来几年&#xff0c;Prompt工程将沿着多个新方向发展&#xff0c;这些方向不仅会改变我们与AI互动…

Android平台RTMP推送|轻量级RTSP服务|GB28181接入之文字、png图片水印的精进之路

技术背景 Android平台推流模块&#xff0c;添加文字或png水印&#xff0c;不是一件稀奇的事儿&#xff0c;常规的做法也非常多&#xff0c;本文&#xff0c;我们主要是以大牛直播SDK水印迭代&#xff0c;谈谈音视频行业的精进和工匠精神。 第一代&#xff1a;不可动态改变的文…

[ROS 系列学习教程] 建模与仿真 - ros_control 介绍

ROS 系列学习教程(总目录) 本文目录 一、ros_control 架构1.1 hardware_interface1.2 combined_robot_hw1.3 controller_interface1.4 controller_manager1.5 controller_manager_msgs1.6 joint_limits_interface1.7 transmission_interface1.8 realtime_tools 二、ros_control…