嵌入式学习第二十九天!(数据结构的概念、单向链表)

news2024/9/21 4:30:57

数据结构:

1. 定义:

    一组用来保存一种或者多种特定关系的数据的集合(组织和存储数据)

    1. 程序设计:

        将现实中大量而复杂的问题以特定的数据类型和特定的数据结构存储在内存中,并在此基础上实现某个特定的功能的操作(程序 = 数据结构 + 算法)

    2. MVC软件设计架构:

        M:mode,数据的管理(数据结构)

        V:view,视图,数据的反映及人机交互

        C:ctrl,逻辑控制

2. 数据与数据之间的关系

    1. 数据的逻辑结构:数据元素与元素之间的关系

        集合:关系平等

        线性结构:元素之间一对一的关系(表(数组、链表)),队列,栈)

        树形结构:元素之间一对多的关系(二叉树)

        图形结构:元素之间多对多的关系(网状结构)

    2. 数据的物理结构:数据的逻辑结构在计算机内存中的存储形式

        1. 顺序存储:

            采用一段连续的内存空间保存元素

            优点:数据访问方便

            缺点:1. 数据插入删除需要移动大量的元素

                       2. 需要预分配内存空间

                       3. 容易造成存储空间碎片

        2. 链式存储:

            采用一种非连续的内存空间保存元素

            优点:1. 插入删除数据效率高

                       2. 不需要预分频内存

            缺点:访问元素必须遍历,效率低

        3. 索引存储:

            通过关键字构建索引表,通过索引表来找到数据的存储位置

        4. 散列存储(哈希存储):

            将数据元素的存储位置与关键码之间建立确定对应关系从而实现查找的存储方式

             索引存储和散列存储都是为了提高数据的查找速度

单向链表:

    1. 有头链表:

        第一个链表节点中不存储有效数据

嵌入式学习第十五天!(内存管理、链表)-CSDN博客

    2. 无头链表:

        第一个链表结点中存储有效数据

        1. 定义无头链表的句柄和结点:

#ifndef _LINK_H_
#define _LINK_H_

typedef int DATA_TYPE;

typedef struct node
{
	DATA_TYPE data;
	struct node *pnext;

}LINK_NODE;


typedef struct list
{
	LINK_NODE *phead;
	int curlen;

}LINK_LIST;

#endif

            说明其中struct node还未定义的时候就用struct node *定义pnext:因为不管是char *还是int *等还是struct node *都是指针类型,它都占8个字节,但是如果不加*,那么系统就不知道结构体构建的内存空间的大小,所以就会报错。

        2. 创建无头链表:

LINK_LIST *Create_Link(void)
{
	LINK_LIST *plist = malloc(sizeof(LINK_LIST));
	if(plist == NULL)
	{
		return NULL;
	}

	plist->phead = NULL;
	plist->curlen = 0;

	return plist;
}

        3. 头插法:

int Push_Head_Link(LINK_LIST *plist, DATA_TYPE data)
{
	LINK_NODE *pnode = malloc(sizeof(LINK_NODE));
	if(pnode == NULL)
	{
		return -1;
	}

	pnode->data = data;
	pnode->pnext = NULL;

	pnode->pnext = plist->phead;
	plist->phead = pnode;

	plist->curlen++;

	return 0;
}

        4. 尾插法:

int Push_Tail_Link(LINK_LIST *plist, DATA_TYPE data)
{
	LINK_NODE *pnode = malloc((sizeof(LINK_NODE)));
	if(pnode == NULL)
	{
		return -1;
	}
	
	pnode->data = data;
	pnode->pnext = NULL;

	LINK_NODE *ptmp = plist->phead;
	if(ptmp == NULL)
	{
		ptmp = pnode;
	}
	else
	{
		while(ptmp->pnext != NULL)
		{
			ptmp = ptmp->pnext;
		}
		ptmp->pnext = pnode;
	}
	plist->curlen++;

	return 0;
}

        5. 遍历:

int list_for_each(LINK_LIST *plist)
{
	LINK_NODE *ptmp = plist->phead;

	while(ptmp != NULL)
	{
		printf("%d ", ptmp->data);
		ptmp = ptmp->pnext;
	}
	printf("\n");

	return 0;
}

        6. 尾删法:

int Pop_Tail_Link(LINK_LIST *plist)
{
	LINK_NODE *ptmp = plist->phead;

	if(ptmp == NULL)
	{
		return 0;
	}
	else if(ptmp->pnext == NULL)
	{
		free(ptmp);
		plist->phead = NULL;
	}
	else
	{
		while(ptmp->pnext->pnext == NULL)
		{
			ptmp = ptmp->pnext;
		}
		free(ptmp->pnext);
		ptmp->pnext = NULL;
	}

	plist->curlen--;

	return 0;
}

        7. 头删法:

int Pop_Head_Link(LINK_LIST *plist)
{
	LINK_NODE *ptmp = plist->phead;

	if(ptmp == NULL)
	{
		return 0;
	}
	else if(ptmp->pnext == NULL)
	{
		free(ptmp);
		plist->phead = NULL;
	}
	else
	{
		plist->phead = plist->phead->pnext;
		free(ptmp);
	}
	plist->curlen--;

	return 0;
}

        8. 查找:

LINK_NODE *Find_Link_Node(LINK_LIST *plist, DATA_TYPE data)
{
	LINK_NODE *ptmp = plist->phead;
	
	while(ptmp != NULL)
	{
		if(ptmp->data == data)
		{
			return ptmp;
		}
		ptmp = ptmp->pnext;
	}

	return NULL;
}

        9. 修改:

int Replace_link_data(LINK_LIST *plist, DATA_TYPE olddata, DATA_TYPE newdata)
{
	LINK_NODE *ptmp = plist->phead;

	while(ptmp != NULL)
	{
		if(ptmp->data = olddata)
		{
			ptmp->data = newdata;
		}
		ptmp = ptmp->pnext;
	}

	return 0;
}

        10. 销毁:

int Destroy_Link(LINK_LIST *plist)
{
	LINK_NODE *ptmp = plist->phead;
	LINK_NODE *pfree = plist->phead;

	while(ptmp != NULL)
	{
		ptmp = ptmp->pnext;
		free(pfree);
		pfree = ptmp;
	}
	free(plist);

	return 0;
}

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

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

相关文章

CTF题型 SSTI(1) Flask-SSTI-labs 通关 题记

CTF题型 SSTI(1) Flask-SSTI-labs 通关 题记 文章目录 CTF题型 SSTI(1) Flask-SSTI-labs 通关 题记前记获取键值或下标的方式获取属性的方式 Level 1 no wafLevel 2 bl[\{\{]Level 3 no waf and blindLevel 4 bl[[, ]]获取键值或下标 Level 5 bl[\, "]Level 6 bl[_]Level …

高通 8255 基本通信(QUP)Android侧控制方法说明

一:整体说明 高通8255芯片中,SPI IIC UART核心统一由QUP V3 进行控制 QUP V3为可编程模块,可以将不同通道配置为SPI IIC UART通路,此部分配置在QNX侧 QUP 资源可以直接被QNX使用,Android侧可以通过两种方法使用QUP资源…

一次完整的 HTTP 请求所经历的步骤

1: DNS 解析(通过访问的域名找出其 IP 地址,递归搜索)。 2: HTTP 请求,当输入一个请求时,建立一个 Socket 连接发起 TCP的 3 次握手。如果是 HTTPS 请求,会略微有不同。 3: 客户端向服务器发…

B树B+树,字典树详解,哈夫曼树博弈树

目录 B树&#xff1a;B-Tree B树 字典树&#xff1a;Trie Tree 哈夫曼树 博弈树 B树&#xff1a;B-Tree 多路平衡搜索树 1.M阶B树&#xff0c;就是M叉&#xff08;M个指针&#xff09;。 2.每个节点内记录个数<M-1。 3.根节点记录个数>1。 4.其余节点内记录个数&…

JavaScript之继承

继承 父类与子类 子类是父类的一个子集 比如&#xff1a;人类和医生类&#xff0c;医生类是人类的子集&#xff1b;人类是父类&#xff0c;医生类是子集 父类与子类在特性&#xff08;属性和方法&#xff09;上有什么关系 方法&#xff1a;子类对象可以调用父类原型上的方…

Nadaraya-Watson核回归

目录 基本原理 ​编辑 核函数的选择 带宽的选择 特点 应用 与注意力机制的关系 参考内容 在统计学中&#xff0c;核回归是一种估计随机变量的条件期望的非参数技术。目标是找到一对随机变量 X 和 Y 之间的非线性关系。 在任何非参数回归中&#xff0c;变量 Y 相对于变量…

Jenkins 一个进程存在多个实例问题排查

Jenkins 一个进程存在多个实例问题排查 最近Jenkins升级到2.440.1​版本后&#xff0c;使用tomcat​服务部署&#xff0c;发现每次定时任务总会有3-4个请求到我的机器人上&#xff0c;导致出现奇奇怪怪的问题。 问题发现 机器人运行异常&#xff0c;总有好几个同时请求的服务。…

Selenium 自动化 —— 使用WebDriverManager自动下载驱动

上一篇文章 入门和 Hello World 实例 中&#xff0c;我们提供了一个最简单的 Selenium 上手的例子。 但是某一天&#xff0c;突然发现相同的代码居然运行报错了。这是怎么回事呢&#xff1f; 日志排查 日志中其实提示的很明显了&#xff1a;Chrome浏览器和Chrome WebDriver的…

python中如何解析Html

在最近需要的需求中&#xff0c;需要 python 获取网页内容&#xff0c;并从html中获取到想要的内容。这里记录一下两个比较常用的python库对html的解析。 1. BeautifulSoup 它是一个非常流行的python脚本库&#xff0c;用于解析HTML和XML文档。如果你对 java 很熟悉&#xff…

软件测试教程 自动化测试之Junit框架

文章目录 1. 什么是 Junit &#xff1f;2. 常见的注解2.1 Test2.2 BeforeAll&#xff0c;AfterAll2.3 BeforeEach&#xff0c;AfterEach 3. 测试用例顺序指定4. 参数化4.1 单个参数4.2 多个参数4.3 通过方法生成 5. 测试套件6. 断言6.1 断言相等6.2 断言不相等6.3 断言为空6.4 …

医疗器械经营许可证办理流程及申请流程有哪些?

1、证书内容差异&#xff1a; 1.医疗器械经营许可证应当载明许可证号码、法定代表人、负责人、住所、经营范围、仓库地址、发证部门、日期及有效期、公司名称等事项。 2.医疗器械生产经营管理注册证书应当载明编号、公司产品名称、法定代表人、住所、经营活动场所、业务发展方…

小程序云开发(十六):JavaScript基础

&#x1f517; 运行环境&#xff1a;小程序云开发 &#x1f6a9; 撰写作者&#xff1a;左手の明天 &#x1f947; 精选专栏&#xff1a;《python》 &#x1f525; 推荐专栏&#xff1a;《算法研究》 &#x1f510;#### 防伪水印——左手の明天 ####&#x1f510; &#x1f497…

计算机网络:TCP篇

计网tcp部分面试总结 tcp报文格式&#xff1a; 序列号&#xff1a;通过SYN传给接收端&#xff0c;当SYN为1&#xff0c;表示请求建立连接&#xff0c;且设置序列号初值&#xff0c;后面没法送一次数据&#xff0c;就累加数据大小&#xff0c;保证包有序。 确认应答号&#x…

基于C/C++的easyx图形库教程

文章目录: 一&#xff1a;前言 二&#xff1a;窗口&#xff08;宽高 背景颜色 窗口标题 弹出对话框&#xff09; 三&#xff1a;图形绘制&#xff08;点 线 矩形 圆 椭圆&#xff09; 四&#xff1a;文字&#xff08;颜色 大小 背景 位置 打印 文字居中&#xff09; 五&a…

动态规划(算法竞赛、蓝桥杯)--单调队列优化绿色通道

1、B站视频链接&#xff1a;E45 单调队列优化DP 绿色通道_哔哩哔哩_bilibili #include <bits/stdc.h> using namespace std; const int N5e410; int n,tim,w[N],f[N],q[N];bool check(int m){int h1,t0;for(int i1; i<n; i){while(h<t && f[q[t]]>f[i-…

鸿蒙Harmony应用开发—ArkTS声明式开发(绘制组件:Line)

直线绘制组件。 说明&#xff1a; 该组件从API Version 7开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。 子组件 无 接口 Line(value?: {width?: string | number, height?: string | number}) 从API version 9开始&#xff0c;该接…

巧用眼精星一键批量识别营业执照为结构化Excel

在现代社会&#xff0c;数字化办公已成为企业管理的重要方式之一。而在处理营业执照等票证文件时&#xff0c;如何高效准确地进行识别和管理也显得尤为重要。眼精星票据识别系统作为一款优秀的OCR识别软件&#xff0c;为用户提供了便捷快速的解决方案。接下来&#xff0c;我们将…

Java安全基础 关键概念过关

Java安全基础 关键概念汇总 文章目录 Java安全基础 关键概念汇总前置知识1.构造器this以及包的使用2.继承3.重写/ 重载 / super4.多态5.区分和equals方法6.toString的使用7.Object的概念8.static,final,代码块static代码块final 9.动态代理10.类的动态加载1)类加载器含义&#…

SpringBoot2.7集成Swagger3

Swagger2已经在17年停止维护了&#xff0c;取而代之的是 Swagger3&#xff08;基于openApi3&#xff09;&#xff0c;所以新项目要尽量使用Swagger3. Open API OpenApi是业界真正的 api 文档标准&#xff0c;其是由 Swagger 来维护的&#xff0c;并被linux列为api标准&#x…

组建公司办公网络

一 认识网络传输介质的分类 网络传输介质主要分为有线传输介质和无线传输介质两大类&#xff0c;它们在网络建设和数据传输中扮演着至关重要的角色。下面是这两类传输介质的详细分类&#xff1a; 有线传输介质 双绞线&#xff08;Twisted Pair&#xff09;&#xff1a;这是最…