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

本文探讨了数据结构和算法在常规开发中的重要性。数据结构如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.最好、最坏、平均情况:以平均为主,最坏为下限;知道其时间开销;

相关推荐
Fanxt_Ja2 天前
【LeetCode】算法详解#15 ---环形链表II
数据结构·算法·leetcode·链表
今后1232 天前
【数据结构】二叉树的概念
数据结构·二叉树
散1123 天前
01数据结构-01背包问题
数据结构
消失的旧时光-19433 天前
Kotlinx.serialization 使用讲解
android·数据结构·android jetpack
Gu_shiwww3 天前
数据结构8——双向链表
c语言·数据结构·python·链表·小白初步
苏小瀚3 天前
[数据结构] 排序
数据结构
睡不醒的kun3 天前
leetcode算法刷题的第三十四天
数据结构·c++·算法·leetcode·职场和发展·贪心算法·动态规划
吃着火锅x唱着歌3 天前
LeetCode 978.最长湍流子数组
数据结构·算法·leetcode
Whisper_long3 天前
【数据结构】深入理解堆:概念、应用与实现
数据结构
IAtlantiscsdn3 天前
Redis7底层数据结构解析
前端·数据结构·bootstrap