数据结构与算法概述

程序 = 数据结构 + 算法
            ---某图灵奖得主

数据结构

基本数据单位

基本数据单位

数据>>数据对象>>>数据元素>>>>数据项


逻辑结构

常见的几种结构有集合结构线性结构树形结构图形结构,其中:

线性结构:有序数据元素集合,比如队列、栈、字符串、数组、链表
树形结构:一对多,比如二叉树,红黑树

物理结构

顺序存储结构

链式存储结构

分两种,一种是顺序存储结构,一种是链式存储结构


算法

解决特定问题的指令序列

特点:输入输出、有穷性、确定性、可行性
评价标准:正确性、可读性、健壮性、效率高

效率度量

时间复杂度
大O表示法
  1. 用常数1取代运行时间中所有常数 3->1 O(1)
  2. 在修改运行次数函数中,只保留最高阶项 n^{3}+2n^{2}+5 -> O(n^{3})
  3. 如果在最高阶存在且不等于1,则去除这个项目相乘的常数 2n^{3} ->O( n^{3})
常见的时间复杂度
执⾏次数函数 术语
12 O(1) 常数阶
2n+3 O(n) 线性阶
3n^{2}+2n+1 O(n^{2}) 平方阶
5\log_2{n} + 20 O(\log_2{n}) 对数阶
2n+3n\log_2{n}+19 O(n\log_2{n}) n\log_2{n}
6n^{3}+2n^{2}+3n+4 O(n^{3}) ⽴方阶
2n O(2n) 指数阶

时间复杂度描述的是算法的最坏情况。

空间复杂度(转载_罗小黑)

对于一个算法,所有的变量、指令、结果都需要存储空间,另外在算法的执行过程中,临时变量和临时结果也需要保留下来以便下一步计算,这些称为算法执行时的辅助空间。空间复杂度主要定性描述算法所需的辅助空间。

空间复杂度相对来说比较简单,只需要关注算法在执行时消耗的辅助空间即可,例如,swap() 函数中 temp 元素的消耗就是辅助空间。当然这个函数还能更高级,看大佬这里

一个好的算法是什么样的?

正确性高、可读性强、健壮性高、效率高
正确性:毋庸置疑,首先必须正确,切实解决问题;
可读性:代码规范,易读注释,逻辑清晰,简单明了,但不是代码越少越好;
健壮性:输入考虑容错、边界值、输出;
效率:时间、空间按业务取舍;

欢迎留言讨论

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 初衷 学习数据结构与算法的知识,并没有一个完备的理由。如果是作为一名算法工程师,这无可厚非,但对于我们大部分的开发...
    大大纸飞机阅读 3,068评论 1 5
  • 数据结构是什么? 数据结构,可以将之分为“数据”和“结构”两个方面去理解。 数据,很好理解。都说人离不开空气,感觉...
    飞扬code阅读 304评论 0 1
  • 前言 写了长一段时间代码,一直对数据结构与算法有些模糊的概念,一直都是调试调试,真成了代码的复杂粘贴的搬运工了,这...
    joshul阅读 726评论 0 11
  • 作为一名非科班出身的程序员,要修炼的内功其实挺多的。现在就开始记录自己修炼数据结构与算法的路程。从数据结构与算法的...
    奔向算法的喵阅读 1,529评论 0 5
  • 概述 在当今程序员的世界,算法已经成为衡量一名程序员水平高低的参照物。高深的程序员都会看重数据结构和算法的作用,水...
    GoFuncChan阅读 219评论 0 1