CSP-S 2019初赛知识点总结之主定理

2024-01-07 08:48

本文主要是介绍CSP-S 2019初赛知识点总结之主定理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

主定理

转载自这里

先介绍几个符号的含义。

符号 Θ \Theta Θ ,读音西塔,既是上界也是下界,等于,严格贴紧。

符号 O O O,读音殴,表示上界,小于等于,贴紧未知。

符号 o o o,读音也是殴,小于,不贴紧。

符号 Ω \Omega Ω,读音偶眯嘎,表示下界,大于等于,贴紧未知。

符号 ω \omega ω,读音也是偶眯嘎,表示下界,大于,不贴紧。

上面的“贴紧”是我根据tight翻译过来的(不是很准确啊),大概就是是否严格等于的意思吧。

意思就是 Θ \Theta Θ是平均时间复杂度, O O O是最坏情况下的复杂度, Ω \Omega Ω是最好情况下的复杂度。

假设我们有递推关系式:

T ( n ) = a T ( n b ) + f ( n ) T(n)=aT(\frac{n}{b})+f(n) T(n)=aT(bn)+f(n)

其中, n n n 为问题的规模、 a a a 为递推下子问题的数量, n b \frac{n}{b} bn 为每个子问题的规模, f ( n ) f(n) f(n) 为递推后做的额外的计算工作。

1.假设存在常数 ϵ \epsilon ϵ>0,使得 f ( n ) = O ( n l o g b ( a ) − ϵ ) f(n)=O(n^{logb(a) − \epsilon}) f(n)=O(nlogb(a)ϵ),则 T ( n ) = Θ ( n l o g b ( a ) ) T(n)=\Theta(n^{logb(a)}) T(n)=Θ(nlogb(a))

具体意思是 f ( n ) f(n) f(n) 的上界是 n n n 的幂次,且 l o g b ( a ) logb(a) logb(a) 比这个幂次要大,则时间复杂度为这个n的 l o g b ( a ) logb(a) logb(a)次。

例子:二叉树的遍历。 T ( n ) = 2 T ( n 2 ) + Θ ( 1 ) T(n)=2T(\frac{n}{2})+Θ(1) T(n)=2T(2n)+Θ(1)。其中 a = 2 a=2 a=2 b = 2 b=2 b=2 f ( n ) = 1 f(n)=1 f(n)=1,此时 ϵ = 1 ϵ=1 ϵ=1 T ( n ) = Θ ( n ) T(n)=Θ(n) T(n)=Θ(n)

2.假设存在常数k≥0,使得 f ( n ) = Θ ( n l o g b ( a ) l o g k n ) f(n)=\Theta(n^{logb(a)}log^{k}n) f(n)=Θ(nlogb(a)logkn),则 T ( n ) = Θ ( n l o g b ( a ) l o g k + 1 n ) 。 T(n)=\Theta(n^{logb(a)}log^{k+1}n)。 T(n)=Θ(nlogb(a)logk+1n)

具体意思是 f ( n ) f(n) f(n) n n n l o g b ( a ) logb(a) logb(a) 次,再乘以一个 l o g log log,则复杂度是 f ( n ) f(n) f(n) 的复杂度再乘以一个 l o g log log

例子:归并排序。 T ( n ) = 2 T ( n 2 ) + Θ ( n ) T(n)=2T(\frac{n}{2})+\Theta(n) T(n)=2T(2n)+Θ(n)。其中 a = 2 a=2 a=2 b = 2 b=2 b=2 f ( n ) = n f(n)=n f(n)=n,此时 k = 0 k=0 k=0 T ( n ) = Θ ( n l o g 2 n ) T(n)=\Theta(nlog^{2}n) T(n)=Θ(nlog2n)

例子:二分搜索(折半搜索)。 T ( n ) = T ( n 2 ) + Θ ( 1 ) T(n)=T(\frac{n}{2})+\Theta(1) T(n)=T(2n)+Θ(1),其中 a = 1 a=1 a=1 b = 2 b=2 b=2 f ( n ) = 1 f(n)=1 f(n)=1,此时 k = 0 k=0 k=0,则 T ( n ) = Θ ( l o g 2 n ) T(n)=\Theta(log^{2}n) T(n)=Θ(log2n)

3.假设存在常数ϵ>0 ,有 f ( n ) = Ω ( n l o g b ( a ) + ϵ ) f(n)=Ω(n^{logb(a)+ϵ}) f(n)=Ω(nlogb(a)+ϵ),同时存在常数 c < 1 c<1 c<1以及充分大的 n n n 满足 a f ( n b ) ≤ c f ( n ) af(\frac{n}{b})≤cf(n) af(bn)cf(n)那么 T ( n ) = Θ ( f ( n ) ) T(n)=\Theta(f(n)) T(n)=Θ(f(n))

在这里插入图片描述

这篇关于CSP-S 2019初赛知识点总结之主定理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/579383

相关文章

关于C++中的虚拟继承的一些总结(虚拟继承,覆盖,派生,隐藏)

1.为什么要引入虚拟继承 虚拟继承是多重继承中特有的概念。虚拟基类是为解决多重继承而出现的。如:类D继承自类B1、B2,而类B1、B2都继承自类A,因此在类D中两次出现类A中的变量和函数。为了节省内存空间,可以将B1、B2对A的继承定义为虚拟继承,而A就成了虚拟基类。实现的代码如下: class A class B1:public virtual A; class B2:pu

嵌入式软件工程师应聘知识点

嵌入式软件工程师应聘 修改浏览权限 | 删除 数据结构(C语言)部分常考的知识点: 1、局部变量能、全局变量和静态变量 2、堆和栈 3、Const、volatile、define、typedef的用途 4、链表(比如链表的插入、删除和排序) 5、排序(考查冒泡法的较多) 6、可重入函数 、malloc函数 7、指针(常考函数指针,函数指针,数组指针,指针数组和

十五.各设计模式总结与对比

1.各设计模式总结与对比 1.1.课程目标 1、 简要分析GoF 23种设计模式和设计原则,做整体认知。 2、 剖析Spirng的编程思想,启发思维,为之后深入学习Spring做铺垫。 3、 了解各设计模式之间的关联,解决设计模式混淆的问题。 1.2.内容定位 1、 掌握设计模式的"道" ,而不只是"术" 2、 道可道非常道,滴水石穿非一日之功,做好长期修炼的准备。 3、 不要为了

数据库期末复习知识点

A卷 1. 选择题(30') 2. 判断范式(10') 判断到第三范式 3. 程序填空(20') 4. 分析填空(15') 5. 写SQL(25') 5'一题 恶性 B卷 1. 单选(30') 2. 填空 (20') 3. 程序填空(20') 4. 写SQL(30') 知识点 第一章 数据库管理系统(DBMS)  主要功能 数据定义功能 (DDL, 数据定义语

人工智能机器学习算法总结神经网络算法(前向及反向传播)

1.定义,意义和优缺点 定义: 神经网络算法是一种模仿人类大脑神经元之间连接方式的机器学习算法。通过多层神经元的组合和激活函数的非线性转换,神经网络能够学习数据的特征和模式,实现对复杂数据的建模和预测。(我们可以借助人类的神经元模型来更好的帮助我们理解该算法的本质,不过这里需要说明的是,虽然名字是神经网络,并且结构等等也是借鉴了神经网络,但其原型以及算法本质上还和生物层面的神经网络运行原理存在

Java注解详细总结

什么是注解?         Java注解是代码中的特殊标记,比如@Override、@Test等,作用是:让其他程序根据注解信息决定怎么执行该程序。         注解不光可以用在方法上,还可以用在类上、变量上、构造器上等位置。 自定义注解  现在我们自定义一个MyTest注解 public @interface MyTest{String aaa();boolean bbb()

tensorboard-----summary用法总结

Tensorflow学习笔记——Summary用法         最近在研究tensorflow自带的例程speech_command,顺便学习tensorflow的一些基本用法。 其中tensorboard 作为一款可视化神器,可以说是学习tensorflow时模型训练以及参数可视化的法宝。 而在训练过程中,主要用到了tf.summary()的各类方法,能够保存训练过程以及参数分布图并在

七种排序方式总结

/*2018.01.23*A:YUAN*T:其中排序算法:冒泡排序,简单排序,直接插入排序,希尔排序,堆排序,归并排序,快速排序*/#include <stdio.h>#include <math.h>#include <malloc.h>#define MAXSIZE 10000#define FALSE 0#define TRUE 1typedef struct {i

Java实现MD5加密总结

Java实现MD5加密总结 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿! 1. 什么是MD5加密 MD5是一种常用的哈希算法,用于将任意长度的数据通过哈希运算转换为固定长度的数据串,通常为128位的二进制串,常用于对密码等敏感信息进行加密存储或传输。 2. Java实现MD5加密的方法 2.1 使用java.sec

Linux通配符总结

Linux通配符总结 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿! 在Linux系统中,通配符是一种用于匹配文件名或路径名的特殊字符。通过使用通配符,可以方便地匹配多个文件或目录,从而进行文件操作或查找。 2. 常用的通配符 在Linux系统中,常用的通配符包括以下几种: *:匹配任意长度的任意字符。?:匹配任意单个字符