【DAY11 软考中级备考笔记】数据结构 排序&&操作系统

数据结构 排序&&操作系统 3月14日 -- 天气:晴

今天天气非常热,已经到20度了,春天已经来了。

1. 堆排序

  • 堆排序的思想是首先建立一个堆,然后弹出堆顶元素,剩下的元素再形成一个堆,然后继续弹出元素,直到所有元素都被弹出。

  • 堆排序通常被应用于求解Top K问题

  • 空间复杂度是1,时间复杂度是nlgn

  • 是不稳定的排序

  • 注意构建堆的方法

2. 归并排序

归并排序的思想是基于分治法。将两个有序的序列合并为一个有序序列,直到整个序列都有序

时间复杂度为nlogn,空间复杂度为n。原因是需要保存排序后的元素。

稳定排序

3. 基数排序

基数排序的基本思想是:

  • 首先建立n个桶,每一个桶的容量为带排序元素个数
  • 然后依次将所有的元素映射到不同的桶中
  • 然后将所有的桶中的元素再收回
  • 然后继续比较下一位
  • 当所有位数都比较完毕,则元素有序

因此时间复杂度为 带排序元素的长度最大位数 *(将所有元素映射到桶即元素个数+将所有元素从桶中收回即进制

空间复杂度为一个二维数组 有排序元素的长度最大位数行,有进制

https://blog.csdn.net/m0_46975599/article/details/112174826

https://zhuanlan.zhihu.com/p/126116878

4. 操作系统的定义

  • 操作系统的定义:有效的管理计算机软硬件资源,合理规划工作流程和程序的执行,并且为用户提供良好的工作环境和人机交互界面
  • 两大作用:
    • 管理计算机资源
    • 为用户提供良好的人机交互界面

5. 操作系统四大特征

5.1 并发性

并发: 指两个或多个事件在同一时间间隔内发生,这些事件宏观上时同时发生的,但在微观上是交替发生的。

**并行:**指两个或多个事件在同一时刻发生。

操作系统的并发性: 指计算机系统中"同时"的运行着多个程序,这些程序宏观上是同时运行的,在微观上是交替运行的。

我们的计算机的CPU有单核的,双核的,四核的,八核的!

单核CPU同一时刻只能运行一个程序,各个程序只能并发的执行(交替的使用CPU)!

多核CPU同一时刻可以执行多个程序,多个程序可以并行的执行(同时发生运行)

5.2 共享性

共享: 即资源共享,是指系统中的资源可供内存中多个并发执行的进程中同时使用。

所谓"同时",往往是宏观上的,而在微观上,这些进程可能是交替的对资源进行访问的(即分时共享)。

两种资源共享方式:互斥共享方式和同时共享方式!

互斥共享方式: 系统中的某些资源,虽然可以提供给多个进程使用,但一个时间段内只允许一个进程访问该资源!

同时共享方式:系统中的某些资源,允许一个时间段内由多个进程"同时"对它们进行访问!

并发性和共享性互为存在条件的!

5.3 虚拟性

虚拟: 是指一个物理上的实体变为若干个逻辑上的对应物,物理实体(前者)是实际存在的,而逻辑上对应物(后者)是用户感受到的。

5.4 异步性

异步:再多道程序环境下,允许多个程序并发的执行,但由于资源有限,进程的执行不是一管到底的,而是走走停停已不可预知的速度向前推进,这就是进程的异步性!

只有系统拥有并发性,才有可能导致异步性

6. 操作系统的分类

7. 程序和进程

进程被创建后,进入新建状态。当这个进程被分配了除了CPU以外其他所有的资源时,会进入就绪状态

7. 进程的通信

n-5最多有n-5个进程会进入阻塞状态

相关推荐
jackson凌22 分钟前
【Java学习笔记】equals方法
java·笔记·学习
龙湾开发1 小时前
计算机图形学编程(使用OpenGL和C++)(第2版)学习笔记 10.增强表面细节(一)过程式凹凸贴图
c++·笔记·学习·3d·图形渲染
XiaoyaoCarter2 小时前
每日一道leetcode(新学数据结构版)
数据结构·c++·算法·leetcode·职场和发展·哈希算法·前缀树
晴空闲雲2 小时前
数据结构与算法-线性表-单链表(Linked List)
数据结构·算法·链表
自学互联网2 小时前
系统集成项目管理工程师学习笔记
笔记·学习
HappyAcmen3 小时前
线代第二章矩阵第九、十节:初等变换、矩阵的标准形、阶梯形与行最简阶梯形、初等矩阵
笔记·学习·线性代数·矩阵
freyazzr3 小时前
Leetcode刷题 | Day63_图论08_拓扑排序
数据结构·c++·算法·leetcode·图论
一梦浮华3 小时前
自学嵌入式 day 18 - 数据结构 1
数据结构
lil44x_3 小时前
嵌入式学习笔记DAY21(双向链表、Makefile)
笔记·学习
ai.Neo3 小时前
牛客网NC22015:最大值和最小值
数据结构·c++·算法