数据结构基础篇

什么是数据结构?

数据结构是指一组数据的存储结构。

什么是算法?

算法是操作一组数据的方法。

10个常用的数据结构

数组、链表、栈、队列、散列表、二叉树、堆、跳表、图、Trie树

10个算法

递归、排序、二分查找、搜索、哈希算法、贪心算法、分治算法、回溯算法、动态规划、字符串匹配算法

数据结构和算法概括

时间复杂度

大O时间复杂度表示法

所有代码的执行时间T(n)与每行代码的执行次数n成正比;

T(n) = O(f(n)

T(n)代表代码的执行时间;n表示数据规模;f(n)表示每行代码执行的次数总和;

O表示代码的执行时间T(n)与表达式f(n)成正比;

公式中的低阶、常量、系数都可以忽略;

大O时间复杂度(简称时间复杂度)

大O时间复杂度实际上并不是具体表示代码真正的执行时间,而是表示代码的执行时间随数据规模增长的变化趋势,所以也叫渐进时间复杂度。、

时间复杂度分析

* 只关注循环执行次数最多的那段代码;

* 加法法则:总复杂度等于量级最大的那段代码的复杂度;

* 乘法法则:嵌套代码复杂度等于嵌套内外代码复杂度的乘积;

几种常见的时间复杂度分析

常量阶:O(1)                                                                    指数阶:O(2n)#2的n次方

对数阶:O(logn)                                                               阶乘阶:O(n!)

线性阶:O(n)

线性对数阶:O(nlogn)

平方阶:O(n²)、立方阶:O(n³)、k次方阶:O(nk)


对于上面罗列的复杂度量级,可以粗略的分为两类,多项式量级非多项式量级。非多项式量级只有两个:指数阶和阶乘阶;

把时间复杂度为多项式量级的算法问题叫做NP(Non-Deterministic Polyomial,非确定多项式)问题;

O(1)

只要代码的执行时间不随着n的增大而增长,这样的时间复杂度都计作O(1)。或者说:一般情况下,只要算法中不存在循环语句、递归语句,即使有成千上万行的代码,其时间复杂度也是O(1);

O(logn)、O(nlogn)

对数阶时间复杂度非常常见,同时也是最难分析的一种。如常用的归并排序、快速排序的时间复杂度都是O(nlogn);

空间复杂度分析

时间复杂度的全称是渐进时间复杂度,表示算法的执行时间与数据规模之间的增长关系;空间复杂度全称就是渐进空间复杂度,表示算法的存储空间与数据规模之间的增长关系;

我们常用的空间复杂度就是O(1)、O(n)、O(n²),像O(logn)、O(nlogn)这样的对数阶复杂度平时用不到;


浅析最好、最坏、平均、均摊时间复杂度

最好情况时间复杂度

在最理想的情况下,执行这段代码的时间复杂度;

最坏情况时间复杂度

在最糟糕的情况下,执行这段代码的时间复杂度;

平均情况时间复杂度

平均时间复杂度的全称应该叫做加权平均时间复杂度或者期望时间复杂度;

均摊时间复杂度以及它对应的分析方法,摊还分析(或者叫平摊分析)

对于一个数据结构进行一组连续操作中,大部分情况下时间复杂度都很低,只有个别情况下时间复杂度比较高,而且这些操作之间存在前后连贯的时序关系,这个时候,我们就可以将这一组操作放在一块分析,看是否能将较高时间复杂度那次操作的耗时,平摊到其他那些时间复杂度比较低的操作上。而且,再能够应用均摊时间复杂度分析的场合,一般均摊时间复杂度就等于最好情况时间复杂度;均摊时间复杂度是一种特殊的平均时间复杂度;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,098评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,213评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,960评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,519评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,512评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,533评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,914评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,804评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,563评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,644评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,350评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,933评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,908评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,146评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,847评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,361评论 2 342

推荐阅读更多精彩内容

  • 一些概念 数据结构就是研究数据的逻辑结构和物理结构以及它们之间相互关系,并对这种结构定义相应的运算,而且确保经过这...
    Winterfell_Z阅读 5,646评论 0 13
  • 算法是解决特定问题求解步骤的描述,在计算机中表现为指令的有限序列,并且每条指令表示一个或多个操作。 为了解决某个或...
    开心糖果的夏天阅读 308评论 0 4
  • 父类实现深拷贝时,子类如何实现深度拷贝。父类没有实现深拷贝时,子类如何实现深度拷贝。• 深拷贝同浅拷贝的区别:浅拷...
    JonesCxy阅读 989评论 1 7
  • • 深拷贝同浅拷贝的区别:浅拷贝是指针拷贝,对一个对象进行浅拷贝,相当于对指向对象的指针进行复制,产生一个新的指向...
    WSGNSLog阅读 1,227评论 0 1
  • [数据结构与算法之美:如何分析、统计算法的执行效率和资源消耗?(03)] 一、如何分析、统计算法的执行效率和资源消...
    luke_阅读 907评论 0 0