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

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

相关推荐
爱coding的橙子3 分钟前
CCF-CSP认证考试准备第十七天
数据结构·c++·算法
程序猿阿伟1 小时前
《C++移动语义:解锁复杂数据结构的高效之道》
数据结构·c++·html
594h22 小时前
PAT 甲级 1002题
数据结构·c++·算法
snowful world2 小时前
vs2022链表的创建和打印(c语言版)
c语言·数据结构·链表
shylyly_3 小时前
归并排序
数据结构·算法·归并排序·递归归并排序·非递归归并排序
itoshi rin4 小时前
简单题21 - 合并两个有序链表(Java)20240917
java·数据结构·链表
Antonio9155 小时前
【高级数据结构】树状数组
数据结构·c++·算法
大晴的上分之旅5 小时前
树和二叉树基本术语、性质
数据结构·算法·二叉树
Chase-Hart6 小时前
【每日一题】LeetCode 815.公交路线(广度优先搜索、数组、哈希表)
数据结构·算法·leetcode·散列表·宽度优先
Am心若依旧4096 小时前
[C++进阶[六]]list的相关接口模拟实现
开发语言·数据结构·c++·算法·list