DAY 2 - 3 : 线性表—顺序存储

news2024/11/27 16:53:40

线性表—顺序表

        问题引入:

线性表

        定义

        若干数据元素的一个线性序列。

        表示

        L = (D,R) (即线性表L包含数据元素集合D和关系集合R)

        D={ ai | ai∈datatype ,i=0,1,2...n-1 ,n≥0}

        R={ <ai,ai+1> | ai,ai+1∈D, 0 ≤ i ≤ n - 2}

        < ai,ai+1 >在这里称为有序对。

        ai是ai+1的直接前驱,ai+1是ai的直接后继。

        举例:

         特征

  •         表头元素没前驱
  •         表尾元素无后继
  •         其他元素有且仅有一个直接前驱和直接后继。

顺序存储结构的表示

        将线性表L=(a0,a1, ……,an-1)中的各元素依次存储于计算机一片连续的存储空间。

        特征 

                优点

  •         逻辑相邻的元素ai,ai+1,存储位置也相邻。
  •         对数据元素ai的存取为随机存取或按地址存取。
  •         存储密度高。

                缺点

  •         对表的插入和删除等运算的时间复杂度较差。比如:假设在文章开始阶段的图书管理系统002位置插入一本书,那么后面所有书本都需要向下移动一个格。

        顺序表的实现

//sqlist.h
#define N 128
typedef int data_t;

typedef struct
{
	data_t data[N];
	int last;
}sqlist, * sqlink;

        设线性表 L=(a0,a1, ……,an-1),对 L的基本运算有:

        1.建立一个空表:list_create(L)

//sqlist.h
sqlink list_creat();
//整体思路:
//1.malloc
//2.初始化
//3.返回线性表的地址
//sqlist.c
sqlink list_creat()
{
	sqlink = L;
	L = malloc(sizeof(sqlist));
	if (L == NULL)
	{
		printf("释放空间失败!\n");
		return L;
	}
	memset(sqlink, 0, sizeof(sqlist));
	L->last = -1;//last = -1 代表空菜单为 -1
	return L;
}

        2.置空表:list_clear(L)「相当于初始化」

//sqlist.h
int list_clear(sqlink L);
//sqlist.c
int list_clear(sqlink L)
{
	sqlink = L;
	if(L == NULL)
	{
		return -1;
	}
	memset(sqlink, 0, sizeof(sqlist));
	L->last = -1;
	return 0;
}

        3.判断表是否为空:list_empty(L)。若表为空,返回值为1,否则返回 0

//sqlist.h
int list_empty(sqlink L);
//sqlist.c
int list_empty(sqlink L)
{
	if (L->last == -1)
	{
		printf("空表格!\n");
		return 1;
	}
	return 0;
}

        4.求表长:length(L)

        5.取表中某个元素:GetList(L,i),即a;。要求0≤islength(L)-1

        6.定位运算:Locate(L,x)。确定元素x在表L中的位置(或序号)

//sqlist.h
int list_locate(sqlink L, data_t value);
//sqlist.c
int list_locate(sqlink L, data_t value)
{
	int i = 0;
	while (i <= L->last)
	{
		if (value == L->data[i])
		{
			return i;
		}
		i++;
	}
	return -1;
}

        7. 插入:

        Insert(L,x,i)。将元素x插入到表L中第i个元素ai之前,且表长+1。

        插入前:(a0,a1,.....ai-1,ai,ai+1....an-1)

        插入后:(a0,a1,....ai-1,x,ai,...an-1)

//sqlist.h
int list_insert(sqlink L,data_t n,pos);
//整体思路:
//1.检查线性表是否是满
//2.pos[0,last]
//3.从后往前移动
//4.赋值
//5.last+1
//sqlist.c
int list_insert(sqlink L,data_t n,pos)
{
	if (L -> last == N - 1)
	{
		printf("线性表是满的!\n");
		return -1;
	}
	if (pos<0 || pos>L->last + 1);
	{
		printf("超出范围!\n");
		return -1;
	}
	int i;
	for (i = L -> last; i >= pos; i--)
	{
		L -> data[i + 1] = L -> data[i];
	}
	L->data[pos] = n;
	L->last++;
	return 0;
}

        8. 删除:

        Delete(L,i)。删除表L中第i个元素ai,且表长减1,要求0≤i≤n-1。

        删除前: (a0,a1,---,ai-1,ai,ai+1-------,an-1)

        删除后:(a0,a1,---,ai-1,ai+1-------,an)

int list_del(sqlink L, int pos)
{
	if (L == NULL)
	{
		return -1;
	}
	if (L->last == -1)
	{
		printf("列表空!\n");
		return -1;
	}
	if (pos < 0 || pos > L->last)
	{
		printf("无效地址!\n");
		return -1;
	}
	for (int i = pos + 1; i <= L->last; i++)
	{
		L->data[i-1] = L->data[i];
	}
	L->last--;
	return 0;
}

        应用:假设线性表La={1,3,5,7},Lb={5,7,9,11},取并集存入La。

        应用:删除线性表的重复元素。

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

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

相关文章

数据结构代码集训day14(适合考研、自学、期末和专升本)

题目均来自b站up&#xff1a;白话拆解数据结构&#xff01; 今日题目如下&#xff1a;&#xff08;1&#xff09;试写一个算法判断给定字符序列是否是回文。 &#xff08;2&#xff09;给定一个算法判断输入的表达式中括号是否匹配。假设只有花、中、尖三种括号。 题1 回文序列…

学习笔记 | 一文搞懂MySQL体系架构!!!(day22)

本文章的内容会在后面文章中慢慢讲解&#xff0c;该文章主要给各位博友zaipin提供学习思路&#xff0c;也希望大家在评论区发言表述&#xff0c;觉得文章有不足指出也可点评&#xff0c;希望大家多多支持&#xff01;&#xff01;&#xff01; 目录 一、MySQL 1.1 数据库概述 …

【项目日记】高并发内存池---实现页缓存

放纵自己的欲望是最大的祸害&#xff1b; 谈论别人的隐私是最大的罪恶&#xff1b; 不知自己过失是最大的病痛。 --- 亚里士多德 --- 高并发内存池---实现页缓存 1 页缓存整体设计思路2 框架搭建3 NewSpan函数4 请求Span联动 1 页缓存整体设计思路 首先我们来看页缓存的设…

windows手工杀毒-寻找可疑进程之进程名称

上篇回顾&#xff1a;windows手工杀毒-寻找可疑进程之进程图标-CSDN博客 上篇中我们简单介绍了什么是电脑病毒&#xff0c;也介绍了一种发现可疑进程的方法即根据进程图标确认是否是病毒&#xff0c;这种方法存在的理论基础是&#xff0c;通过图标可以很容易在电脑上找…

遥控器新手操作指南!!!

一、准备工作 检查电量&#xff1a;确保无人机和遥控器的电池电量充足&#xff0c;以避免在飞行过程中因电量不足而导致意外。 安装与连接&#xff1a;确保无人机的螺旋桨安装正确且牢固&#xff0c;同时检查无人机存储卡是否插入&#xff0c;以及遥控器与无人机之间的连接是…

论文笔记:2023顶会SIGIR - Strategy-aware Bundle Recommender System

论文笔记&#xff1a;2023顶会SIGIR - Strategy-aware Bundle Recommender System

【位运算】--- 初阶题目赏析

Welcome to 9ilks Code World (๑•́ ₃ •̀๑) 个人主页: 9ilk (๑•́ ₃ •̀๑) 文章专栏&#xff1a; 算法Journey 根据上一篇位运算的总结&#xff0c;我们来体会几道初阶题目。 &#x1f3e0; 判定字符是否唯一 &#x1f4cc; 题目解析 判定字符是否唯一…

通义千问AI PPT初体验:一句话、万字文档、长文本一键生成PPT!

大家好&#xff0c;我是木易&#xff0c;一个持续关注AI领域的互联网技术产品经理&#xff0c;国内Top2本科&#xff0c;美国Top10 CS研究生&#xff0c;MBA。我坚信AI是普通人变强的“外挂”&#xff0c;专注于分享AI全维度知识&#xff0c;包括但不限于AI科普&#xff0c;AI工…

leecode刷题经典算法套路模版笔记【递归回溯篇】--根本逻辑,快速掌控

刷题套路总结&#xff1a; 双指针&#xff1a; 单调性&#xff1b;对两端按照规律进行操作移动&#xff1b; 常见移法&#xff0c;右指针右移扩大范围&#xff0c;左指针左移缩小范围&#xff1b; 先举例模拟&#xff0c;然后推导公式&#xff1b; 递归&#xff0c;回溯 &am…

线程间同步的方式有哪些?

Linux 系统提供了五种用于线程间同步的方式&#xff1a;互斥锁、读写锁、自旋锁、信号量、条件变量 互斥锁 主要用于保护共享数据&#xff0c;确保同一时间内只有一个线程访问数据。 互斥量本质上来说就是一把锁&#xff0c;在访问共享资源前对互斥量进行加锁&#xff0c;访…

【go-zero】win启动rpc服务报错 panic: context deadline exceeded

win启动rpc服务报错 panic: context deadline exceeded 问题来源 在使用go-zero生成的rpc项目后 启动不起来 原因 这个问题原因是wndows没有启动etcd 官方文档是删除了etcd配置 而我自己的测试yaml配置有etcd&#xff0c;所以需要启动etcd 下载安装好etcd后&#xff0…

Java Full GC 的常见原因及优化策略

Java Full GC 的常见原因及优化策略 1、导致Full GC的常见原因1.1 新生代设置过小1.2 新生代设置过大1.3 Survivor区设置不当 2、优化GC策略2.1 吞吐量优先2.2 暂停时间优先 3、结论 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 在Java应…

自控原理-传递函数(闭环 扰动 偏差 前馈 复合 顺馈)

都知道闭环传递函数定义为&#xff1a;G1G2/(1G1G2H) 但是当碰到复杂的系统&#xff0c;比如复合顺馈&#xff0c;前馈扰动等&#xff0c;就不知道分子到底要不要乘上G2了。 这个公式是如何推导出来的&#xff0c;今天看到一个公式图片&#xff1a; 过程非常详细。 由此我也…

C语言遇见的一些小问题

问题如下&#xff1a; 1&#xff1a;为什么这样的代码为报错 #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <algorithm> #include <cstdio> #include<string> #include<stdlib.h> using namespace std; int main() {int i …

C语言 ——— #define定义标识符

目录 #define 定义常变量 #define 定义字符串 #define 定义一条代码 #define 定义的标识符是否需要加分号 #define 定义常变量 代码演示&#xff1a; #define M 100 //定义常变量 代码用途&#xff1a; int a M; int arr[M] { 0 }; 此时的 M 具有常属性&#xff0c…

什么是UART?

1.什么是UART&#xff1f; 通用异步收发传输器&#xff08;Universal Asynchronous Receiver/Transmitter)&#xff0c;通常称作UART。UART 表示通用异步接收机/发射机&#xff0c;定义用于在两个设备之间交换串行数据的协议或一组规则。UART 非常简单&#xff0c;仅在发射机和…

C语言中static与extern关键字的深入解析

在C语言编程中&#xff0c;static和extern是两个非常重要的关键字&#xff0c;它们各自有着独特的用途。本文将深入探讨这两个关键字的工作原理、底层实现机制以及在实际开发中的应用。 static关键字 1. 原理与作用 static关键字用于声明变量或函数具有特定的作用域和生命周…

5.4分段线性灰度变换

目录 实验原理 分段线性灰度变换的概念 变换函数的形式 示例代码1 示例结果1 示例代码2 示例结果2 示例代码3 运行结果3 示例代码4 运行结果4 实验原理 在OpenCV中&#xff0c;分段线性灰度变换&#xff08;Piecewise Linear Gray Level Transformation&#xff09…

GitLab 是什么?GitLab使用常见问题解答

GitLab 是什么 GitLab是由GitLab Inc.开发&#xff0c;使用MIT许可证的基于网络的Git仓库管理工具开源项目&#xff0c;且具有wiki和issue跟踪功能&#xff0c;使用Git作为代码管理工具&#xff0c;并在此基础上搭建起来的web服务。 ​GitLab 是由 GitLab Inc.开发&#xff0c…

【Prometheus】Prometheus的特点、数据采集方式、架构、数据模型详解

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…