博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C语言实现常用数据结构:基本概念(第0篇)
阅读量:3943 次
发布时间:2019-05-24

本文共 1447 字,大约阅读时间需要 4 分钟。

写在前面:为什么学习C语言数据结构

今天开始,我准备和一起分享学习C语言常用数据结构,这里不求事无巨细的掌握数据结构的方方面面,而是学习编程、考试等实际中常用的重要数据结构,这里以分享可以运行的代码为学习主要方式,因为可运行的代码有时候是最好的老师。

数据结构和算法是十分重要的。C语言+数据结构+算法=C语言程序。考虑下编程的过程:对于一个真实的问题,编程解决步骤往往是:第一步分析问题,第二步找到数学方法“纸面上”解决它,也就是找到“算法”,第三步选择合适的数据结构存放数据,实现“算法”,第四步选择编程语言,编写可执行的代码,实现数据结构和算法。其中第二步很关键,思考算法。

数据结构概念

是指相互之间存在一种或多种关系的数据元素的集合,使用集合二元组来描述有两个要素部分,分别是数据元素集合、数据元素关系集合。

数据结构完整描述可以分为逻辑结构和存储结构,逻辑结构描述本质上的关系,存储结构是根据计算机和编程语言特点实现关系,一种逻辑结构可以有多种存储结构实现,同样,一种存储结构可以被用于实现多种逻辑结构。

逻辑结构分类

逻辑结构对应数据结构中数据元素的关系,简单可以分为集合、线性、树型、图状四类。

  • 集合:最松散的关系,相当于空关系,只要数据元素取值属于同一个集合即可。

  • 线性:一对一关系,数据元素逻辑上结构是排列的一条“线”,有先后次序。

  • 树型:一对多关系,存在一个父亲结点和多个孩子结点,逻辑上是一颗“树”。

  • 图状:多对多关系,数据元素可以有任意的对应关系,形似一张“网图状”。

存储结构分类

存储结构是数据结构的逻辑结构在计算机中的物理实现表示,因此也可以称为物理结构,简单分为2大类:

  • 顺序存储方式:数据按照顺序在内存中存放,数据的逻辑顺序和计算机物理内存地址顺序对应,C语言实现可以使用数组、动态内存分配的顺序表表示。

  • 链式存储方式:数据可以在内存中随机存放,同时数据结点中通过一个指针将数据按照逻辑顺序串接起来,例如链表。

算法

  • 算法是对特定问题的求解步骤的描述,是通用的数学意义上的问题求解。

  • 程序是算法在计算机中的一种实现,需要使用特定的编程语言和计算机指令。

  • 算法常见时间复杂度大小关系:O(1)<O(logn)<O(n)<O(nlogn)<O(n2)<O(n3)<O(2n)<O(n!)<O(nn),其中O(1)表示常量时间,和问题规模无关。

  • 算法空间复杂度:是指算法需要除数据元素之外的辅助空间大小,O(1)表示只需要固定的辅助空间,和问题规模无关,原地工作。

对比理解

1.逻辑结构和存储结构:数据结构的两个重要方面,一种逻辑结构可以有多种存储结构实现,存储结构实现和计算机硬件特性、编程语言特性相关,不同的存储结构实现,其数据结构最终的处理效率是不同的,各有优劣。

2.数据结构和算法:这两个概念也是密切相关,算法是对问题的求解,必然涉及到数据处理,因此需要选择数据结构存放数据。使用不同的数据结构直接影响算法对于问题的处理效率。一个可以用计算机解决的实际问题,需要同时选择一个合适的算法和数据结构,最终形成完整的可执行程序。

3.数据结构作用主要是处理数据,因此基本上每种数据结构都需要提供增加、修改、删除、查询、显示数据等通用功能,根据数据结构的具体存储结构,其实现的过程和效率均不相同。

其实做为一个学习者,有一个学习的氛围跟一个交流圈子特别重要这里我推荐一个C/C++基础交流583650410,不管你是小白还是转行人士欢迎入驻,大家一起交流成长。

转载地址:http://ldjwi.baihongyu.com/

你可能感兴趣的文章
Linux(一)- 认识Linux
查看>>
Linux(二)- Linux常用命令
查看>>
Linux(三)- Java开发环境搭建
查看>>
Linux(四)- Ubuntu安装Mysql
查看>>
Ubuntu安装开发环境
查看>>
Deepin开发环境安装
查看>>
Spring入门
查看>>
网址大全
查看>>
Git的使用
查看>>
Linux域名IP映射
查看>>
Java的反射机制
查看>>
SpringCloud微服务应用入门
查看>>
SpringCloud之session共享
查看>>
Springboot集成Shiro实现认证
查看>>
Spring、Spring MVC和MyBatis编程式集成示例
查看>>
在Springboot应用使用redis缓存
查看>>
Spring入门
查看>>
Idea提示键和热部署配置以及git使用
查看>>
Deepin+Vscode搭建vue.js项目及Git操作
查看>>
基于Spring Security前后端分离式项目解决方案
查看>>