数据结构--初步了解(抽象分级)

本文探讨了数据结构和算法在常规开发中的重要性。数据结构如ArrayList用于构建无穷级菜单,线性结构则常用于好友管理。理解数据的逻辑和存储结构、算法的正确性、鲁棒性、简单性、抽象分级和高效性是关键。算法的描述方式包括汉字、流程图、伪代码和实际实现,并通过时间复杂度和空间复杂度评估其效率。在实际应用中,应关注数据结构的合理使用和算法的设计优化。

摘要由CSDN通过智能技术生成

展开

现状:现在毕业以及两年半了,感觉常规开发上面很少用过数据结构以及配套算法。

一般一个程序=数据结构+算法;

目前常规开发,也都是业务代码开发、以及框架自带的配置或者第三方插件直接使用,但是数据结构也是常用的,但是用的很low;

数据结构:可以理解为,对抽象数据定义为一个合理的结构体进行封装,存储在计算机中,方便后续算法使用或者业务代码使用。

例如:

1.实现无穷级菜单,

你能知道使用arraylist进行存储数据,但是呢,你想实现无穷级菜单,就要额外处理了,需要一点算法:

当然肯定又常规的递归,进行初始的无穷级菜单构建数据结构,后续在某个节点上,增加无穷级菜单、以及修改,肯定就涉及到一些基本功了(也可以吧这个理解为算法,就是怎么样合理的处理这个数据结构,让我们实现这个程序或者业务场景)

2.常规微信添加好友,

一般也就是直接备注姓名,不想使用搜索的话,是不是一个个进行查找呢,没加备注的话,是不是更加麻烦,一个个找;

另一种思路就是,将常规好友进行分组备注,例如按照公司分组、好友关系等分组,也是方便查找;

这两种方式是不是也是分别用了,线性和数的结构来存储好友信息,类似的概念;

关于数据

常规了解四点:

1.数据的逻辑结构,用什么样的结构来定义数据的关系;

2.数据的存储结构,这个结构体怎么存储到计算机中;

3.算法,基于这个机构的数据,例如如何实现插入、删除、查找等操作,核心就是怎么处理数据;

4.常规数据处理技术:查找、排序、索引等;

总之:

数据逻辑的四种结构:集合、线性表、树、图,每一种还可以细分,独立不开存储和遍历算法;

数据存储的两种结构:顺序存储、链接存储(会用到指针);索引存储;哈希存储

关于算法

一:也可以理解为程序,要有以下几个特点;

1.正确性:面对任何合法的输入都能给出,正确的结果;

2.鲁棒性:也称为健壮性,对于错误的输入,算法能够识别并处理,而不是产生错误动作或者陷入瘫痪,要有对非法输入的抵抗性;

3.简单性:简单容易理解和实现。
4.抽象分级:算法一旦创建,必须由人进行阅读、理解和修改。如果算法涉及太多,人就会糊涂,要采用抽象分级来组织算法表达的思想,可以理解为吧算法分解为多个模块,模块互调,做好备注、描述功能即可;

5.高效性;

时间效率:运行速度;

空间效率:存储空间大小,也要考虑到GC;

二:算法有四种描述方式:

1.汉字描述,写除步骤

2.流程图

3.伪代码

4.真实实现

三:评价算法的优劣

1.事先估算法:他是对算法所消耗资源的估算。

2.时间复杂度:判断算法的时间代价,o(1)最合适;

3.空间复杂度:算法执行过程中,需要的辅助空间的数量;
4.最好、最坏、平均情况:以平均为主,最坏为下限;知道其时间开销;

相关推荐
切糕师学AI3 小时前
环形缓冲区(Ring Buffer / Circular Buffer)详解:原理、优势、应用与高性能实现
数据结构·环形缓冲区
WolfGang0073214 小时前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
晚枫歌F6 小时前
最小堆定时器
数据结构·算法
嫩萝卜头儿7 小时前
2 - 复杂度收尾 + 链表经典OJ
数据结构·算法·链表·复杂度
样例过了就是过了8 小时前
LeetCode热题100 分割等和子集
数据结构·c++·算法·leetcode·动态规划
木木_王8 小时前
嵌入式Linux学习 | 数据结构 (Day05) 栈与队列详解(原理 + C 语言实现 + 实战实验 + 易错点剖析)
linux·c语言·开发语言·数据结构·笔记·学习
北顾笙9809 小时前
day38-数据结构力扣
数据结构·算法·leetcode
m0_629494739 小时前
LeetCode 热题 100-----14.合并区间
数据结构·算法·leetcode
@小码农9 小时前
2026年3月Scratch图形化编程等级考试一级真题试卷
开发语言·数据结构·c++·算法
_日拱一卒11 小时前
LeetCode:226翻转二叉树
数据结构·算法·leetcode