数据结构与算法(C语言)------顺序线性表

2023-05-16

顺序线性表

定义:线性表的顺序存储结构,指的是用一段地址连续的存储单元依次存储线性表的数据元素。

线性表的顺序存储的结构代码:

#ifndef __SQLIST_H
#define __SQLIST_H
#include <stdlib.h>
#include <stdio.h>

#define  MAX_SIZE 100

#define OK    1
#define ERROR 0
typedef int states;

typedef char ElementType;
//顺序线性表结构
typedef struct sqlist{
	ElementType data[MAX_SIZE];
	int size;
}SqList;

/** 初始化顺序线性表 */
states InitSqList(SqList * sqlist);

/** 按照位置向顺序线性表插入元素 */
states InsertSqList(SqList *sqlist, int pos, char ch);

/** 按照位置删除线性表中某个元素 */
states DeleteSqList(SqList *sqlist, int pos, char *ch);

/** 获取线性表中元素 */
states GetSqListelem(SqList *sqlist,int pos, char *ch);

/** 打印顺序线性表中元素 */
void PrintfSqList(SqList *sqlist);

#endif /* __SQLIST_H */

顺序存储结构的相关操作代码

#include "SqList.h"

/** 初始化顺序线性表 */
states InitSqList(SqList * sqlist)
{
	int i = 0;
	sqlist->size = 0;
	for(i = 0;i < MAX_SIZE;i++){
		sqlist->data[i] = 0;
	}
	return OK;
}

/** 按照位置向顺序线性表插入元素 */
states InsertSqList(SqList *sqlist, int pos, char ch)
{
	int i;
	//判断线性表是否已满
	if(sqlist->size == MAX_SIZE)
		return ERROR;
	//判断输入位置变量范围是否正确
	if(pos < 1 || pos > sqlist->size + 1)
		return ERROR;
	for(i = sqlist->size;i >= pos;i--){
		sqlist->data[i] = sqlist->data[i-1];
	}
	sqlist->data[pos-1] = ch;
	sqlist->size++;
	return OK;
}
/** 按照位置删除线性表中某个元素 */
states DeleteSqList(SqList *sqlist, int pos, char *ch)
{
	int i;
	if(sqlist->size == 0)
		return ERROR;
	if(pos < 1 || pos > sqlist->size)
		return ERROR;
	*ch = sqlist->data[pos-1];
	for(i = pos;i <= sqlist->size - 1;i++){
		sqlist->data[i-1] = sqlist->data[i];
	}
	sqlist->size--;
	return ERROR;
}

/** 获取线性表中元素 */
states GetSqListelem(SqList *sqlist,int pos, char *ch)
{
	if(sqlist->size == 0)
		return ERROR;
	if(pos < 1 || pos > sqlist->size)
		return ERROR;
	*ch = sqlist->data[pos-1];
	return OK;
}

/** 打印顺序线性表中元素 */
void PrintfSqList(SqList *sqlist)
{
	int i;
	printf("顺序线性表中的元素:\n");
	for(i = 0;i < sqlist->size;i++){
		printf("%c ",sqlist->data[i]);
	}
	printf("\n");
}

编程笔记:

  • 向线性表中插入元素:
    1、判断线性表是否已满
    2、判断输入pos变量的范围,可以当前线性表中最后一个元素的后面插入一个新的数据,所以 pos = sqlist->size +1 。
    3、位于pos位置后面的元素,向后移动一位。
    公式:data[i] = data[i-1];
    判断条件可以根据公式去决定 :(i = sqlist->size;i >= pos;i–)
    注:如果插入的在线性表最后元素的后面的话,不用移动元素直接插入数据。
    pos = sqlist->size + 1 不进入for循环
    4、插入元素。
  • 从线性表中删除元素:
    1、判断线性表是否为空
    2、判断输入pos变量的范围,(1 ~sqlise->size)。
    3、获取删除元素。
    4、位于pos位置后面的元素,向前移动一位。
    公式:data[i-1] = data[i];
    判断条件可以根据公式去决定 :(i = pos;i <= sqlist->size -1;i++)
    注:如果删除线性表最后的元素,不用移动元素直接删除数据。
    pos = sqlist->size 不进入for循环
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

数据结构与算法(C语言)------顺序线性表 的相关文章

  • 五大常用经典算法

    五大常用算法之一 分治算法 一 基本概念 在计算机科学中 分治法是一种很重要的算法 字面上的解释是 分而治之 就是把一个复杂的问题分成两个或更多的相同或相似的子问题 再把子问题分成更小的子问题 直到最后子问题可以简单的直接求解 原问题的解即
  • C语言/C++实现栈操作

    一 栈的概念 栈是一种常用的数据结构 它遵循先入后出 Last In First Out LIFO 的原则 栈的操作只在栈的一端进行 该端被称为栈顶 而另一端称为栈底 栈的基本操作包括压栈 入栈 push 和弹栈 出栈 pop 分别用于将元
  • 01背包问题变种:从长度为n的数组里选出m个数使和为固定值sum

    这个问题是我从leetcode上一道问题所想到的 原题 如果是从数组中选出2个数相加使之成为固定的数sum 这当然很简单 把数组中的数字遍历一遍 判断另一个数字是否也在数组中即可 代码如下 vector
  • netty handler的执行顺序(3)

    2019独角兽企业重金招聘Python工程师标准 gt gt gt 今天解决2个问题 1 handler在pipeline当中究竟是如何存储的 2 在遍历handler的过程中 会根据event的不同 调用不同的handler 这一点是如何
  • 将二叉树转为有序的双向链表

    一 题目要求 输入一棵二叉排序树 现在要将该二叉排序树转换成一个有序的双向链表 而且在转换的过程中 不能创建任何新的结点 只能调整树中的结点指针的指向来实现 include
  • 直线检测方法—LSD论文翻译

    附原文链接 LSD a Line Segment Detector 摘 要 LSD是一个线段检测器 能够在线性时间内得到亚像素级精度的检测结果 它无需调试参数就可以适用于任何数字图像上 并且能够自我控制错误数量的检测 平均来说 一个图像中允
  • Qt——用于表格QTableView的模型

    如果想使用表格来呈现数据 Qt提供了一个方便的部件QTableWidget 但是直接用它实现一些功能可能比较困难 这里将介绍一种强大 灵活的方式来操作表格 一 模型 视图架构 在这个架构中 模型用于存储数据 视图用于呈现数据 除此之外 还有
  • Hash table and application in java

    查找的效率取决于在查找是比较的次数 次数越少效率越高 反之越低 最理想的情况是无需比较 一次存取便能找到所查找的记录 根据对应关系f找到给定值K的像f K hash function 应运而生 由此思想建的表称为hash table 集合h
  • JavaScript实现数据结构 -- 链表

    文章目录 链表 链表的特点 链表和数组的区别 JS模拟链表 遍历链表 插入节点 删除节点 链表应用 删除链表中的节点 leetcode 237 思路 代码 反转链表 leetcode 206 思路 代码 链表 链表和数组一样是有多个元素组成
  • 链表和线性表的优缺点

    链表和线性表的优缺点 作为我们最先接触的两个数据结构 链表和线性表的优缺点都较为明显 并且二者互相补足 文章目录 链表和线性表的优缺点 线性表 线性表的组成 线性表的缺点 线性表的优点 链表 链表的组成 链表的优点 链表的缺点 总结 线性表
  • 常用的十种算法--马踏棋盘算法

    1 马踏棋盘算法介绍 马踏棋盘算法也被称为骑士周游问题 将马随机放在国际象棋的 8 8 棋盘 Board 0 7 0 7 的某个方格中 马按走棋规则 马走日字 进行移动 要求每个方格只进入一次 走遍棋盘上全部 64 个方格 2 马踏棋盘算法
  • DDP入门

    DDP 即动态动态规划 可以用于解决一类带修改的DP问题 我们从一个比较简单的东西入手 最大子段和 带修改的最大子段和其实是常规问题了 经典的解决方法是用线段树维护从左 右开始的最大子段和和区间最大子段和 然后进行合并 现在我们换一种方法来
  • 递归算法中的时间复杂度分析

    对于一种算法的时间复杂度分析还是特别重要的 在一些非递归算法中 我们仅仅看运算次数最多的那一行代码可能执行多少次就可以 实际就是看在循环中变量的变化 但是对于递归算法中该怎么分析呢 下面介绍几种递归函数中的算法时间复杂度分析的方法 0 递推
  • 数据结构小白之插入排序算法

    1 插入排序 1 1 思路 将n个需要排序的元素看成两个部分 一个是有序部分 一个是无序部分 开始的时候有序表只有一个元素 无序表有n 1个元素 排序过程中每次从无序表中取出元素 然后插入到有序表的适当位置 从而成为新的有序表 类似排队 如
  • 『Python基础-15』递归函数 Recursion Function

    什么是递归函数 一种计算过程 如果其中每一步都要用到前一步或前几步的结果 称为递归的 用递归过程定义的函数 称为递归函数 例如连加 连乘及阶乘等 凡是递归的函数 都是可计算的 即能行的 递归就是一个函数在它的函数体内调用它自身 编程语言中的
  • 数据结构之图的两种遍历实现(C语言版)

    上一期文章分享完了图的两种遍历方式 也是两种很重要的算法 DFS和BFS 这两种算法的应用和重要性我就不多说了 内行的人懂的都懂 今天这文章重要就是来上机实现这两种算法 又由于这两种算法都可以由邻接矩阵和邻接表来表示 博主分享的代码都是上机
  • 字符串09--表示数值的字符串

    字符串09 表示数值的字符串 jz53 题目概述 解析 参考答案 注意事项 说明 题目概述 算法说明 请实现一个函数用来判断字符串是否表示数值 包括整数和小数 例如 字符串 100 5e2 123 3 1416 和 1E 16 都表示数值
  • 人工智能概念

    人工智能概念 人工智能就是用人工方法在机器 计算机 上实现的智能 或称机器智能 即是研究如何用计算机来表示和执行人类的智能活动 以模拟人脑所从事的推理 学习 思考和规划等思维活动 并解决需要人类的智力才能处理的复杂问题 如医疗诊断 管理决策
  • 雪糕的最大数量 排序+贪心

    雪糕的最大数量 雪糕的最大数量 题目描述 样例 数据范围 思路 代码 题目描述 夏日炎炎 小男孩 Tony 想买一些雪糕消消暑 商店中新到 n 支雪糕 用长度为 n 的数组 costs 表示雪糕的定价 其中 costs i 表示第 i 支雪
  • 从源码角度来谈谈 HashMap

    HashMap的知识点可以说在面试中经常被问到 是Java中比较常见的一种数据结构 所以这一篇就通过源码来深入理解下HashMap 1 HashMap的底层是如何实现的 基于JDK8 1 1 HashMap的类结构和成员 HashMap继承

随机推荐

  • NUCLEO开发板 STLINK-V3E体验

    一 前言 NUCLEO开发板普遍在内部集成了ST LINK调试器 编程器 xff0c 所以STM32 Nucleo 144板无需单独的探头 个人理解 xff0c STLINK V3E中 xff0c E是Embedded的意思 xff0c 也
  • GAZEBO 中 sdf文件详解

    GAZEBO 中 sdf文件详解 1 model模型 一个模型数据库会拥有的文件 xff08 1 xff09 database config xff1a 有关数据库的元数据 xff0c 从CMakeList自动填充 本地不需要 xff08
  • 【HCNP-OSPF】LSA

    一 拓扑图 OSPF为什么会引入 划分区域 xff1f 划分区域以后 xff0c 可以带来以下好处 xff1a 1 节省区域中的每一个设备的系统资源 xff08 大区域被划分以后 xff0c 小区域中的数据库内容就会变少 xff09 xff
  • 无人机起降(2):AcFly飞控模块与M8N GPS模块的接口修改

    假如AcFly飞控想使用M8NGPS而不是AcFly GPS 需要将接线进行更换 AcFly飞控接口定义 由飞控手册查阅外设接口 xff1a 超声波 xff1a Ultrasonic 接口 光流传感器 xff1a Uart5 接口 GPS
  • 卡尔曼滤波原理及应用仿真(3):非线性滤波之扩展Kalman滤波

    标量非线性系统EKF 标量系统状态方程 xff1a 观测方程 xff1a MATLAB仿真 设置时间长度为50s xff0c 过程噪声方差Q 61 0 01 观测噪声方差R 61 1 xff0c 初值X 0 61 0 1 xff0c 协方差
  • 100条经典C++笔试题目及答案分享

    100条经典C 43 43 笔试题目分享 一 C 43 43 与C差异 1 17 二 数据类型 关键字 18 37 三 C 43 43 面向对象的特性 38 61 四 程序阅读题 62 89 五 编程练习 90 100 看到好用的经典C 4
  • 2020讯飞AI开发者大赛-温度预测赛道baseline改进

    2020讯飞AI开发者大赛 温度预测赛道baseline改进分享 写在前面数据清洗缺失值处理异常值处理 特征工程模型训练写在最后 写在前面 这是我参加的第二次数据竞赛 xff0c 上次是上个月的 传染病趋势预测 xff0c 西交是主办方的那
  • office显示正在更新怎么办

    问题 xff1a office打开之后 xff0c 显示正在更新 xff0c 过了一段时间后显示失败 xff0c 怎么解决 xff1f 解决方案 xff1a 1 win 43 R输入services msc 2 将Microsoft Off
  • pandas.DataFrame.select_dtypes的用法

    做数据分析时 xff0c 需要对特征进行归类 类别型还是数值型 xff0c pandas提供了select dtypes函数 函数原型 DataFrame select dtypes include 61 None exclude 61 N
  • SQL中if语句的使用

    SQL代码 xff1a select cast allcardid as bigint as allcardid is lord won if lord total bomb cnt 61 0 1 lord used bomb cnt 1
  • pandas.facctorize

    pandas factorize用法 对标签进行数值编码 相当于label encoding xff0c 按照标签在data中出现的先后顺序 span class token keyword import span pandas span
  • 录制好的视频文件,如何添加到直播源中做成直播?

    阿酷原创 2017 11 27 长沙 录制好的视频文件 xff0c 如何添加到直播源中做成直播 xff1f 打开直播助手界面 xff0c 点击 34 添加素材 34 xff0c 就可以添加音视频文件了 xff0c 选择你要添加的视频文件 x
  • pandas随机打乱dataFrame顺序

    pandas sample frac 61 sample frac 61 0 5 随机取data的一半数据 sample frac 61 1 0 随机取data的所有数据 xff0c 相当于打乱顺序 span class token key
  • pandas.dataFrame索引重置

    pandas 重置索引 data span class token operator 61 span pd span class token punctuation span span class token function DataFr
  • Ubuntu更新内核版本-Mainline(ukuu免费版本的延续)——一个带有图形和控制台界面的程序,用于更新内核

    要安装程序 xff0c 请运行以下命令 xff1a sudo apt add repository y ppa cappelikan ppa sudo apt update sudo apt install mainline 要启动图形界面
  • 无人机各个类型介绍

    为了执行 xff0c 无人机可能由类似的元件制成 xff0c 但无论是它们的能力 xff0c 还是由什么组成的 xff0c 它们都在某种程度上有所不同 大多数无人机都是为了执行特定任务而制造的 xff0c 因此以特定的方式建造 xff0c
  • 知识图谱概述(图谱学苑课程)

    1 知识图谱概念 知识图谱本质上是基于图的语义网络 xff0c 表示实体和实体之间的关系 构建知识图谱的目的 xff0c 就是让机器具备认知能力 xff0c 理解这个世界 2 知识图谱研究的多个维度 2 1 知识图谱相关发展领域 知识图谱是
  • 关于keils中#include后的双引号““与尖引号<>的区别

    关于keils中 include后的双引号 34 34 与尖引号 lt gt 的区别 关于 include 后的 与 lt gt KEILS中 include后的 与 lt gt 关于 include 后的 与 lt gt lt gt 搜索
  • UC/OS-III学习——触发PendSV中断

    UC OS III学习 触发PendSV中断 前言一 关于PendSV的基础知识二 代码1 c语言2 汇编语言 前言 PendSV典型使用场合是在上下文切换时 xff08 在不同任务之间切换 xff09 本文主要介绍触发PendSv中断的两
  • 数据结构与算法(C语言)------顺序线性表

    顺序线性表 定义 xff1a 线性表的顺序存储结构 xff0c 指的是用一段地址连续的存储单元依次存储线性表的数据元素 线性表的顺序存储的结构代码 xff1a span class token macro property span cla