数据结构---顺序表---单链表

 目录

一、什么是程序?

 程序 = 数据结构 + 算法

二、一个程序是否优秀的两个标准 

2.1.时间复杂度

2.2.空间复杂度 

三、数据结构

3.1.数据结构间的关系

1.逻辑结构

1)线性关系

2)非线性关系

2.存储结构

1)顺序存储结构

2)链式存储结构

3)离散存储结构

4)索引存储结构

3.2.主要的数据结构

1.表

2.栈

3.队列

4.树

5.图 

四、顺序表

4.1.定义

 4.2.初始化申请空间

4.3.判断函数

​编辑 

4.4.尾添加

​编辑 

4.5.指定位置插入

​编辑 4.6.遍历

 4.7.删除

4.8.清空

​编辑 

4.8.销毁

​编辑   

五、单链表 

 六、总结


一、什么是程序?

 程序 = 数据结构 + 算法

二、一个程序是否优秀的两个标准 

2.1.时间复杂度

 时间复杂度:数据量增长与程序的执行时间的一种函数关系;

 时间复杂排序由小到大:O(c) < O(logn) < O(n) < O(nlogn) < O(n^2) < O(n^3) < O(2^n);

2.2.空间复杂度 

空间复杂度:数据增长量与程序所占的空间的一种函数关系;

三、数据结构

3.1.数据结构间的关系

1.逻辑结构

1)线性关系

一对一----表

2)非线性关系

一对多---树

多对多---图 

2.存储结构

1)顺序存储结构
2)链式存储结构
3)离散存储结构
4)索引存储结构

3.2.主要的数据结构

1.表

2.栈

3.队列

4.树

5.图 

四、顺序表

4.1.定义

 这里以int为例子

 4.2.初始化申请空间

 

4.3.判断函数

4.4.尾添加

4.5.指定位置插入

注意:指定位置插入后,需要将该位置的往后的所有现有的向后移动 

 4.6.遍历

注意:很重要,里面的函数指针,用来操作查询到的数据的,可以用来查询和修改

 4.7.删除

4.8.清空

4.8.销毁

注意:销毁要释放空间 ,注意主函数

   

五、单链表 

#ifndef _LINKLIST__H_
#define _LINKLIST__H_typedef int DataType;typedef struct node
{DataType data;struct node *pnext;}LinkList;extern LinkList *CreateLinkList(void);
extern int HeadInsertLinkList(LinkList *phead, DataType data);
extern int TailInsertLinkList(LinkList *phead, DataType data);
extern int PrintLinkList(LinkList *phead);
extern int SelectLinkList(LinkList *phead, DataType data);
extern int UpdateLinkList(LinkList *phead, DataType olddata, DataType newdata);
extern int DeleteLinkList(LinkList *phead, DataType data);
extern int CleanLinkList(LinkList *phead);
extern int DestoryLinkList(LinkList *phead);#endif 
#include "linklist.h"
#include <stdio.h>
#include <stdlib.h>/* 创界一个含有头节点的单链表 */
LinkList *CreateLinkList(void)
{LinkList *phead = NULL;phead = malloc(sizeof(LinkList));if (phead == NULL){return NULL;}phead->pnext = NULL;return phead;
}/* 头插法 */
int HeadInsertLinkList(LinkList *phead, DataType data)
{LinkList *pnode = NULL;pnode = malloc(sizeof(LinkList));if (pnode == NULL){return 0;}pnode->data = data;pnode->pnext = phead->pnext;phead->pnext = pnode;return 0;}/* 尾插法 */
int TailInsertLinkList(LinkList *phead, DataType data)
{LinkList *pnode = NULL;LinkList *p = NULL;p = phead;pnode = malloc(sizeof(LinkList));if (pnode == NULL){return 0;}pnode->data = data;while (p->pnext != NULL){p++;}pnode->pnext = NULL;p->pnext = pnode;return 0;}/* 打印数据 */
int PrintLinkList(LinkList *phead)
{  LinkList *ptmp = NULL;if (phead->pnext == NULL){return -1;}ptmp = phead->pnext;while (ptmp != NULL){printf("%d ",ptmp->data);ptmp = ptmp->pnext;}printf("\n");return 0;}/* 查寻 */
int SelectLinkList(LinkList *phead, DataType data)
{LinkList *ptmp = NULL;if (phead->pnext == NULL){return -1;}ptmp = phead->pnext;while (ptmp != NULL){if (ptmp->data == data){printf("%d存在!\n", data);break;}ptmp = ptmp->pnext;}return 0;
}/* 修改 */
int UpdateLinkList(LinkList *phead, DataType olddata, DataType newdata)
{LinkList *ptmp = NULL;if (phead->pnext == NULL){return -1;}ptmp = phead->pnext;while (ptmp != NULL){if (ptmp->data == olddata){ptmp->data = newdata;break;}ptmp = ptmp->pnext;}return 0;
}/* 删除 */
int DeleteLinkList(LinkList *phead, DataType data)
{LinkList *ptmp = NULL;LinkList *qtmp = NULL;if (phead->pnext == NULL){return -1;}ptmp = phead->pnext;qtmp = phead;while (ptmp != NULL){if (ptmp->data == data){qtmp->pnext = ptmp->pnext;free(ptmp);break;}ptmp = ptmp->pnext;qtmp = qtmp->pnext;}return 0;
}/* 清空 */
int CleanLinkList(LinkList *phead)
{LinkList *ptmp = NULL;LinkList *qtmp = NULL;if (phead->pnext == NULL){return -1;}ptmp = phead->pnext;qtmp = phead->pnext;while (ptmp != NULL){ptmp = ptmp->pnext;free(qtmp);qtmp = ptmp;}phead->pnext = NULL;return 0;
}/* 销毁 */
int DestoryLinkList(LinkList *phead)
{LinkList *ptmp = NULL;LinkList *qtmp = NULL;if (phead->pnext == NULL){return -1;}ptmp = phead;qtmp = phead;while (ptmp != NULL){ptmp = ptmp->pnext;free(qtmp);qtmp = ptmp;}return 0;
}
#include "linklist.h"
#include <stdio.h>int main(void)
{LinkList *phead = NULL;phead = CreateLinkList();for (int i = 1; i < 10; i++){//HeadInsertLinkList(phead, i);TailInsertLinkList(phead, i);}PrintLinkList(phead);SelectLinkList(phead, 8);UpdateLinkList(phead, 8, 10);PrintLinkList(phead);DeleteLinkList(phead, 10);PrintLinkList(phead);CleanLinkList(phead);PrintLinkList(phead);DestoryLinkList(phead);return 0;
}

 六、总结

        顺序表和链表的区别很明显,链表空间地址不是连续的,顺序表空间地址是连续的;链表需要的空间大,但是理论上可以存储无限数据,而顺序表需要空间较小,存储的元素个数有限;顺序表访问元素比链表方便。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

exit_hook和setcontext

文章目录 exit_hook概述例题:思路:利用:setcontextglibc-2.27以及 之前glibc-2.29以及之后:exit_hook 概述 大佬文章:exit_hook在pwn题中的应用 - 不会修电脑 - 博客园 (cnblogs.com) exit_hook :是程序在执行exit函数时,会去该位置拿一个函数指针,进而执行的一段程序…

【单片机开发】IAP技术详解及应用

【前言】 在单片机开发过程中&#xff0c;程序的烧录是一个至关重要的环节。随着技术的不断演进&#xff0c;单片机烧录方式也日益多样化。 【单片机开发】单片机的烧录方式详解&#xff08;ICP、IAP、ISP&#xff09;-CSDN博客文章浏览阅读775次&#xff0c;点赞14次&#x…

低空经济概念火爆:无人机飞手人才培养先行

随着科技的飞速发展&#xff0c;低空经济作为新兴的经济形态&#xff0c;正以前所未有的速度崛起&#xff0c;成为推动产业升级和经济发展的新引擎。无人机作为低空经济的重要组成部分&#xff0c;其应用领域已从最初的军事侦察、航拍扩展到农业植保、物流配送、环境监测、应急…

Question mutiple pdf‘s using openai, pinecone, langchain

题意&#xff1a;使用 OpenAI、Pinecone 和 LangChain 对多个 PDF 文件进行提问。 问题背景&#xff1a; I am trying to ask questions against a multiple pdf using pinecone and openAI but I dont know how to. 我正在尝试使用 Pinecone 和 OpenAI 对多个 PDF 文件进行提…

【计算机组成原理】计算机系统的层次结构——计算机软件

计算机系统的层次结构 导读一、计算机软件的分类二、计算机语言三、计算机系统的层次结构3.1 从计算机语言的角度来理解多级层次结构3.2 计算机层次之间的关系3.3 指令集体系结构&#xff08;ISA&#xff09; 结语 导读 大家好&#xff0c;很高兴又和大家见面啦&#xff01;&a…

市占率最高的显示器件,TFT_LCD的驱动系统设计--Part 1

目录 一、简介 二、TFT-LCD驱动系统概述 &#xff08;一&#xff09;系统概述 &#xff08;二&#xff09;设计要点 二、扫描驱动电路设计 &#xff08;一&#xff09;概述 扫描驱动电路的功能 扫描驱动电路的组成部分 设计挑战 驱动模式 &#xff08;二&#xff09…

多目标应用:基于MOPSO的移动机器人路径规划研究(提供MATLAB代码)

一、机器人路径规划介绍 移动机器人&#xff08;Mobile robot&#xff0c;MR&#xff09;的路径规划是 移动机器人研究的重要分支之&#xff0c;是对其进行控制的基础。根据环境信息的已知程度不同&#xff0c;路径规划分为基于环境信息已知的全局路径规划和基于环境信息未知或…

Ubuntu上qt使用SSH样式表

SSH样式表 如果学习过web的同学都知道&#xff0c;我们在学习HTML的时候会用到样式表&#xff0c;我们使用它来更改我们的颜色、大小、背景等等。上到后面&#xff0c;老师会说&#xff1a;我们如果在HTML文件中编辑太多的样式&#xff0c;就会让代码看起来非常的繁琐&#xf…

学习计算机网络

a类0~127&#xff0c;b类128~191&#xff0c;c类192~223 网络地址&#xff1a;看子网掩码&#xff0c;分网络位和主机位&#xff0c;后面是主机位&#xff0c;主机位全部为0&#xff0c;网络地址。 直接广播地址&#xff1a;看子网掩码&#xff0c;分网络位和主机位&#xff…

自建一款开源音乐服务-Navidrome

自建一款开源音乐服务-Navidrome Navidrome&#xff0c;一个开源的音乐服务器和播放器&#xff0c;提供了一个优雅且功能丰富的解决方案&#xff0c;让你的音乐库无论在何处都能触手可及。本文将带你一步步搭建自己的Navidrome音乐服务器&#xff0c;让你的音乐生活更加自由和…

【Qt】关于QMenuBar创建方式的讨论

关于QMenuBar创建方式的讨论 如果在创建项目的时候&#xff0c;没有勾选自动生成ui文件&#xff0c;此时上述代码是正确的&#xff1b;而如果勾选了自动生成ui文件&#xff0c;上述代码则会出现内存泄漏的问题。因为Qt已经生成了一个QMenuBar了 由于之前程序已经自己创建好了一…

STM32 系列MCU 开发利器 STM32CubeIDE

前言 由于自己接触较多的 ARM 系列芯片主要是 STM32 系列的&#xff0c;接触过 STM32 F1、F4、L4、H7 等几个系列&#xff0c;使用的 开发工具&#xff0c;主要是 Keil MDK5、IAR&#xff0c;所以也比较关注开发工具的使用。 Keil MDK5、IAR 属于商用收费的功能强大的IDE&…

【MATLAB】matlab生成的图像如何导出(三种方法教会你)

我们经常使用matlab生成各类的图&#xff0c;如何将其导出&#xff0c;导出为何种类型。 方法一&#xff1a;选择 matlab 生成的图形界面 " Figure 1 " 的菜单栏 " 编辑 " — " 复制图窗 " , 就可以将图像拷贝到 Word 文档中 打开 Word 文档 ,…

单片机编程魔法师-消息处理

消息机制 消息处理的编程思路是当某件事产生后只发送一条事件产生消息以通知相应执行机构执行的一种编程思路。 消息定义 什么是消息&#xff0c;消息是一个指示&#xff0c;可以是数字&#xff0c;字符串&#xff0c;字符或者是任何形式的其他标识符 消息定义的形式与消息…

简易的 Websocket + 心跳机制 + 尝试重连

文章目录 演示大纲基础 WebSocket前端: 添加心跳机制前端: 尝试重新连接历史代码 还没有写完&#xff0c;bug 是有的&#xff0c;我在想解决办法了… 演示 大纲 基础的 webSocket 连接前后端&#xff1a;添加心跳机制后端无心跳反应&#xff0c;前端尝试重新连接设置重新连接…

计算多图的等价无向图的邻接链表表示

计算多图的等价无向图的邻接链表表示 摘要:一、引言二、算法思路三、伪代码实现四、C代码实现五、算法分析六、结论摘要: 在图论中,多图(Multigraph)是一种允许边重复以及存在自循环边(即一个顶点到其自身的边)的图。给定一个多图的邻接链表表示,本文旨在探讨如何构造…

PHP软件下载-安装-环境配置

.1.下载 下载地址如下 windows.php.net - /downloads/releases/ 安装包如下. .2.安装 可以在D盘或者E盘的根目录创建一个自定义目录。注意文件夹目录中不能包含中文&#xff0c;不能包含空格等特殊字符。 版本说明&#xff1a; (1)ts表示非线程安全版本。这个安装包还指明了…

c++模拟实现数据结构之vector篇

那么本篇文章是带大家一起实现一下数据结构vector&#xff0c;那么我们现在就进入正题。 目录 接口介绍部分 增加 尾插 指定插入与头插 删除 尾删 指定位置删除 主要代码逻辑 增加 尾插 指定插入与头插 删除 尾删 指定位置删除 一些其他接口的代码逻辑 模拟实现…

django企业开发实战-学习小结

写在前面 初次阅读此书是三年前&#xff0c;当时没经历过完整的项目 觉得这书就是扯淡 后来经历过项目加班与毒打 今天再翻开此书 觉得实乃不可多得之物 花些时间啃下来吧 django版本 3.2 本博客开源项目地址 kimsmith/django企业实战 (gitee.com) 有的代码因为版本混乱报错…

Unity 3D学习资料集合

本文包含了unity3D 游戏开发相关的学习资料&#xff0c;包含了入门、进阶、性能优化、面试和书籍等学习资料&#xff0c;含金量非常高&#xff0c;在这里分享给大家&#xff0c;欢迎收藏。 学习社区 1.Unity3D开发者 Unity3D开发者论坛是一个专注于Unity引擎的开发者社区。在这…