递归时间复杂度分析方法:Master 定理
编写算法时,可能因为对自己代码的复杂度的不清晰而导致错失良机,对于普通的递推或者说循环的代码,仅用简单的调和级数或者等差数列和等比数列即可分析,但是对于递归的代码,简单的递归树法并不方便,理解并记下Master定理,可以让事情变得轻松。
写此文以作笔记,如有错误,请联系博主。
Master 定理基本形式
对于一个递归式 T ( n ) = a T ( n b ) + f ( n ) T(n) = aT(\frac{n}{b}) + f(n) T(n)=aT(bn)+f(n),其中:
- a ≥ 1 a \geq 1 a≥1 和 b > 1 b > 1 b>1 是常数;
- f ( n ) f(n) f(n) 是一个给定的函数,
Master 定理帮助我们确定 T ( n ) T(n) T(n) 的渐进界。
有三种情况:
- 如果 f ( n ) = O ( n c ) f(n) = O(n^c) f(n)=O(nc),其中 c < log b a c < \log_b{a} c<logba, 那么 T ( n ) = Θ ( n log b a ) T(n) = \Theta(n^{\log_b{a}}) T(n)=Θ(nlogba)。
- 如果 f ( n ) = Θ ( n c ) f(n) = \Theta(n^c) f(n)=Θ(nc),其中 c = log b a c = \log_b{a} c=logba, 那么 T ( n ) = Θ ( n c log n ) T(n) = \Theta(n^c\log{n}) T(n)=Θ(nclogn)。
- 如果 f ( n ) = Ω ( n c ) f(n) = \Omega(n^c) f(n)=Ω(nc),其中 c > log b a c > \log_b{a} c>logba,且满足一定的平滑条件(即 a f ( n / b ) ≤ k f ( n ) af(n/b) \leq kf(n) af(n/b)≤kf(n) 对于某个常数 k < 1 k < 1 k<1 和充分大的 n n n), 那么 T ( n ) = Θ ( f ( n ) ) T(n) = \Theta(f(n)) T(n)=Θ(f(n))。
特定的例子
考虑 T ( n ) = 2 T ( n 2 ) + O ( n log n ) T(n) = 2T(\frac{n}{2}) + O(n\log{n}) T(n)=2T(2n)+O(nlogn),这里 a = 2 a = 2 a=2, b = 2 b = 2 b=2, 和 f ( n ) = n log n f(n) = n\log{n} f(n)=nlogn。显然, f ( n ) f(n) f(n) 不符合 Master 定理的标准形式中的 f ( n ) = O ( n c ) f(n) = O(n^c) f(n)=O(nc),因为增长速度比任何 n c n^c nc 形式要快。因此,直接应用标准 Master 定理的三种情况并无法获得解答。
在这种特殊情况下, T ( n ) = 2 T ( n 2 ) + n log n T(n) = 2T(\frac{n}{2}) + n\log{n} T(n)=2T(2n)+nlogn 的时间复杂度实际上是 O ( n ( log n ) 2 ) O(n(\log{n})^2) O(n(logn)2)。如有兴趣请自行查找证明过程。
相关文章:
递归时间复杂度分析方法:Master 定理
编写算法时,可能因为对自己代码的复杂度的不清晰而导致错失良机,对于普通的递推或者说循环的代码,仅用简单的调和级数或者等差数列和等比数列即可分析,但是对于递归的代码,简单的递归树法并不方便,理解并记…...
实例名不规范导致mds创建失败
概述 在部署ceph集群时,规划主机名、关闭防火墙、配置免密、关闭selinux,配置hosts文件这几步同样重要,都是初期部署一次麻烦,方便后续运维的动作。遇到过很多前期稀里糊涂部署,后续运维和配置时候各种坑。 近期遇到…...
OpenGL中的纹理过滤GL_NEAREST和GL_LINEAR
一、GL_NEAREST(最近邻插值) 1.1 原理 当需要从纹理中采样颜色时,GL_NEAREST模式会选择离采样点最近的纹理像素(通常是最接近采样点的纹理元素的中心),并直接使用该像素的颜色值作为输出。这种模式不进行任…...
vue 性能优化
data 层级不要太深 data 层级太深会增加响应式监听的计算,导致页面初次渲染时卡顿。 合理使用 v-show 和 v-if 频繁切换时,使用 v-show无需频繁切换时,使用 v-if 合理使用 computed computed 有缓存,data 不变时不会重新计算&…...
互联网大厂ssp面经(操作系统:part1)
1. 什么是进程和线程?它们之间有什么区别? a. 进程是操作系统中运行的一个程序实例。它拥有独立的地址空间和资源,可以独立执行。 b. 线程是进程内的一个执行单元,一个进程可以包含多个线程。 c. 线程共享进程的资源,…...
Android Activity 启动涉及几个进程
Zygote进程: Zygote进程在Android系统启动时被初始创建,并且初始化了虚拟机(Dalvik或ART),预加载了Android系统的核心类库。所有的Android应用进程都是通过fork()从Zygote进程派生出来的,这允许应用快速启动࿰…...
说说你对链表的理解?常见的操作有哪些?
一、是什么 链表(Linked List)是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的,由一系列结点(链表中每一个元素称为结点)组成 每个结点包括两个部分&…...
每天五分钟深度学习:逻辑回归算法的损失函数和代价函数是什么?
本文重点 前面已经学习了逻辑回归的假设函数,训练出模型的关键就是学习出参数w和b,要想学习出这两个参数,此时需要最小化逻辑回归的代价函数才可以训练出w和b。那么本节课我们将学习逻辑回归算法的代价函数是什么? 为什么不能平方差损失函数 线性回归的代价函数我们使用…...
llama-factory SFT系列教程 (二),大模型在自定义数据集 lora 训练与部署
文章目录 简介支持的模型列表2. 添加自定义数据集3. lora 微调4. 大模型 lora 权重,部署问题 参考资料 简介 文章列表: llama-factory SFT系列教程 (一),大模型 API 部署与使用llama-factory SFT系列教程 (二),大模型在自定义数…...
C语言游戏实战(11):贪吃蛇大作战(多人对战)
成果展示: 贪吃蛇(多人对战) 前言: 这款贪吃蛇大作战是一款多人游戏,玩家需要控制一条蛇在地图上移动,吞噬其他蛇或者食物来增大自己的蛇身长度和宽度。本游戏使用C语言和easyx图形库编写,旨在…...
腾讯测试岗位的面试经历与经验分享【一面、二面与三面】
腾讯两个月的实习一转眼就结束了,回想起当时面试的经过,感觉自己是跌跌撞撞就这么过了,多少有点侥幸.马上腾讯又要来校招了,对于有意愿想投腾讯测试岗位的同学们,写了一些那时候面试的经历和自己的想法,算不上经验,仅供参考吧! 一面 — —技术基础,全面…...
手机移动端网卡信息获取原理分析
有些场景我们需要获取当前手机上的网卡信息(如双卡双待、Wifi等)。本文准备研究一下这块的原理,以便更好的掌握相关技术原理。 1、底层系统接口 getifaddrs 使用 getifaddrs 接口可以达到我们的目的,该接口会返回本地所有网卡的信…...
无人新零售引领的创新浪潮
无人新零售引领的创新浪潮 在数字化时代加速演进的背景下,无人新零售作为商业领域的一股新兴力量,正以其独特的高效性和便捷性重塑着传统的购物模式,开辟了一条充满创新潜力的发展道路。 依托人脸识别、物联网等尖端技术,无人新…...
SD-WAN提升企业网络体验
在现代企业中,网络体验已成为提升工作效率与业务质量的关键因素。SD-WAN技术的出现,以其独特的优势,为企业提供了优化网络连接、加速数据传输、提升服务质量和应用访问体验,以及增强网络稳定性的解决方案。接下来,我们…...
Docker搭建Let‘s Encrypt
Let’s Encrypt是一个免费、开放和自动化的证书颁发机构(CA),它提供了一种简单、无需重复的机制来获取和更新SSL/TLS证书。Let’s Encrypt Docker镜像允许用户在容器化环境中轻松部署和使用Let’s Encrypt的服务。 主要功能包括:…...
单链表讲解
一.链表的概念以及结构 链表是一种物理结构上不连续,逻辑结构上连续的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。 链表的结构与火车是类似的,一节一节的,数据就像乘客一样在车厢中一样。 与顺序表不同的…...
DFS算法系列 回溯
DFS算法系列-回溯 文章目录 DFS算法系列-回溯1. 算法介绍2. 算法应用2.1 全排列2.2 组合2.3 子集 3. 总结 1. 算法介绍 回溯算法是一种经典的递归算法,通常被用来解决排列问题、组合问题和搜索问题 基本思想 从一个初始状态开始,按一定的规则向前搜索&…...
Linux C应用编程:MQTT物联网
1 MQTT通信协议 MQTT(Message Queuing Telemetry Transport,消息队列遥测传 输)是一种基于客户端-服务端架构的消息传输协议,如今,MQTT 成为了最受欢迎的物联网协议,已广泛应用于车联网、智能家居、即时聊…...
企业常用Linux文件命令相关知识+小案例
远程连接工具无法连接VMWARE: 如果发现连接工具有时连不上,ip存在,这时候我们查看网络编辑器,更多配置,看vnet8是不是10段,nat设置是否是正确的? 软件重启一下虚机还原一下网络编辑器 查看文件…...
Istio介绍
1.什么是Istio Istio是一个开源的服务网格(Service Mesh)框架,它提供了一种简单的方式来为部署在Kubernetes等容器编排平台上的微服务应用添加网络功能。Istio的核心功能包括: 服务治理:Istio能够帮助管理服务之间的…...
C语言对象模型系列(二)从函数指针到虚函数表:彻底理解 C 的多态—— 为什么 device->ops->open() 看起来像 C++?
一、上一篇留下的最大问题 上一篇: C语言对象模型系列(一)为什么 Linux / Android 系统里全是 struct 函数指针?—— 一篇讲透 C 语言如何实现面向对象(OOP) 我们提到: device->ops->…...
手把手教你用S7-1200 V3.0固件连接Modbus TCP服务器(含DB块避坑指南)
手把手攻克S7-1200 V3.0 Modbus TCP连接:从DB块配置到功能码映射实战 第一次用S7-1200连接Modbus TCP设备时,那些看似简单的配置步骤背后藏着不少"暗礁"。我见过太多工程师在数据块指针格式上栽跟头,或是被40001这样的地址编号搞得…...
Qt QColor实战:从基础调色到界面美化的完整指南
1. QColor基础:从RGB到HSV的调色入门 第一次用QColor调色时,我盯着RGB三个参数发呆了半小时——明明想调出薄荷绿,结果调出来的颜色总像发霉的抹布。后来才发现,掌握颜色模型就像学做菜要先认识调料,这是Qt界面美化的第…...
U-Net与自编码器在医学图像分割与特征提取中的实战应用
1. 项目概述:从像素到洞察的桥梁在医学影像分析领域,我们每天面对的是海量的CT、MRI、病理切片图像。对于临床医生和研究员而言,仅仅“看到”图像是不够的,关键在于“理解”和“量化”。比如,一张肺部CT中,…...
构建可信AI:融合信托义务与AI对齐的法律技术框架
1. 项目概述:当法律原则遇上技术挑战最近几年,AI的进化速度让人眼花缭乱,从能写诗画画的大模型,到能自主决策的智能体,它们正以前所未有的深度介入我们的生活和工作。但随之而来的,是一个越来越无法回避的尖…...
Windows驱动管理终极指南:DriverStore Explorer完全使用手册
Windows驱动管理终极指南:DriverStore Explorer完全使用手册 【免费下载链接】DriverStoreExplorer Driver Store Explorer 项目地址: https://gitcode.com/gh_mirrors/dr/DriverStoreExplorer Driver Store Explorer(简称RAPR)是一款…...
眼科AI偏见陷阱全解析:从数据收集到临床部署的七步规避法
1. 项目概述:眼科AI的“偏见陷阱”与系统性规避在眼科诊室里,我见过太多医生对着海量的眼底照片、OCT影像,一坐就是几个小时。人工智能(AI)的到来,尤其是基于深度学习的影像分析,曾被寄予厚望&a…...
ARM虚拟处理器模型在无线设备开发中的关键作用
1. ARM虚拟处理器模型在无线市场中的核心价值 现代无线设备(如智能手机)的设计复杂度正呈指数级增长。以2023年旗舰手机为例,其SoC通常集成: 3-4个ARM Cortex-X/A系列高性能CPU核心 4-6个ARM Cortex-A系列能效核心 1-2个专用DS…...
Zabbix AI技能实战:基于MCP协议实现自然语言监控运维自动化
1. 项目概述 如果你和我一样,在运维Zabbix监控系统超过五年,那你一定经历过这样的场景:凌晨三点被告警电话吵醒,登录Zabbix Web界面,手忙脚乱地点击一个又一个菜单,试图搞清楚到底是哪个主机的哪个触发器出…...
[具身智能-610]:树莓派 4B/5 vs RK3568/RK3588 开发板传感器接口类型与协议
树莓派 4B/5 与 RK3568/RK3588 在传感器接口上的核心差异:树莓派生态完善、易用,但无原生 ADC、接口数量有限、无工业总线;RK3568/RK3588 接口更丰富、带原生 ADC、多路高速摄像头、支持 CAN / 工业总线,更适合工业与多传感器项目…...
