2024年Linux最全数据结构知识点总结(2),Linux运维开发面试基础

最全的Linux教程,Linux从入门到精通

======================

  1. linux从入门到精通(第2版)

  2. Linux系统移植

  3. Linux驱动开发入门与实战

  4. LINUX 系统移植 第2版

  5. Linux开源网络全栈详解 从DPDK到OpenFlow

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

第一份《Linux从入门到精通》466页

====================

内容简介

====

本书是获得了很多读者好评的Linux经典畅销书**《Linux从入门到精通》的第2版**。本书第1版出版后曾经多次印刷,并被51CTO读书频道评为“最受读者喜爱的原创IT技术图书奖”。本书第﹖版以最新的Ubuntu 12.04为版本,循序渐进地向读者介绍了Linux 的基础应用、系统管理、网络应用、娱乐和办公、程序开发、服务器配置、系统安全等。本书附带1张光盘,内容为本书配套多媒体教学视频。另外,本书还为读者提供了大量的Linux学习资料和Ubuntu安装镜像文件,供读者免费下载。

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。

需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以点击这里获取!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

不同的出栈排列个数:

常用的操作有:入栈push,出栈pop。

访问的时间复杂度:O(n)(最坏);

插入/删除的时间复杂度:O(1)。

应用:浏览器的倒退和前进;检查符号是否成对出现(如果是左括号就直接push到stack中,否则将stack的栈顶元素与该括号做比较,不相等就直接返回false);翻转字符串;维护函数调用等。

3. 队列:

先进先出,在多线程阻塞队列管理中非常适用。

队列用数组或链表实现,分别叫做顺序队列和链式队列。

访问的时间复杂度:O(n)(最坏);

插入/删除的时间复杂度:O(1)。

单队列:顺序队列(由数组实现,会出现假溢出现象)和链式队列。

循环队列:解决假溢出和越界问题。循环队列判断队满的常用方法是①设置flag标志位;②使用一个空闲位。

双端队列:元素可以从队头出队和入队,也可以从队尾出队和入队。

优先队列:由堆实现。

***循环队列中元素个数求法:(rear-front+m) % m(取余) ,其中,rear:队列尾指针,front:队列头指针,m:队列容量。

***循环队列中区分队空和队满的方法:

(1)牺牲一个存储单元(入队时少用一个队列单元):

队满条件:(q.rear+1)%maxsize == q.front

队空条件:q.front == q.rear

(2)增设表示元素个数的数据成员:

队满条件:q.size == MaxSize

队空条件:q.front == q.rear

(3)增设tag数据成员:

队满条件:tag == 1

队空条件:tag == 0

4.链表:

物理存储单元上非连续的,非顺序的存储结构;每个元素包含两个节点:数据域和指针域;不需要初始化容量,可以任意加减元素,只需要改变前后2个元素节点的指针域指向地址即可。

***如何判断链表是否有环?

(1)穷举遍历:设一个检测指针k和一个遍历指针q,count记录q走的步数,q每走一步,k就走q之前走过的节点,若发现相同的节点就说明有环。q=NULL时遍历完整个链表。时间复杂度是O(n^2),空间复杂度是O(1)。

(2)标记法:设置一个标记变量,每走一个节点,就判断一次,若visit=true则有环,反之无环。时间复杂度是O(n),空间复杂度是O(n)。

5. 散列表(哈希表):

根据键(key)而直接访问在内存存储位置的数据结构。哈希表建立了关键字和存储地址之间的一种直接映射关系。

  • 构造方法:

(1)直接定址法:直接取关键字的某个线性函数为哈希地址。

(2)除留余数法:假定哈希表长度为m,取一个不大于m但最接近于/等于m的质数P,利用公式H(key)=key%P将关键字转化为哈希地址。

(3)数据分析法:设关键字是r进制数,选取数码分布较为均匀的若干位作为哈希地址。

(4)平方取中法:取关键字的平方值的中间几位作为哈希地址。

  • 哈希冲突的解决方法:

(1)开放寻址法:线性探查法,平方探查法,双重散列探查法,伪随机探查法。

(2)拉链法(链地址法)

(3)再哈希法

6. 非线性数据结构——图:

图的存储使用:①邻接矩阵:二维矩阵,如A[i][j]=n(权值)或者A[i][j]=0/1,无线图的邻接矩阵是对称矩阵。邻接矩阵比较浪费空间。

②邻接表:如下图所示,在无向图中,邻接表元素的个数=边的条数*2;在有向图中,邻接表元素的个数=边的条数。

7. 非线性数据结构——堆:

堆不一定是完全二叉树,任意一个节点的值都 ≥(或≤)所有子节点的值,堆通常用数组表示。

堆的插入和删除效率高,时间复杂度是O(logn),初始化的时间复杂度是O(n)。

***若根节点的序号为1,那么树中任意节点 i,其左子节点序号为 2i,右子节点为 2i+1。

①自底向上堆化:会产生“气泡”浪费存储空间,用于插入元素,即先将元素放至数组末尾,上浮。

②自顶向下堆化:用于删除堆顶元素,将末尾元素放至堆顶,再向下堆化,下沉。

根的下标一定为0,最后一个元素的下标一定为size-1.

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以点击这里获取!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 17
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值