高级算法设计与分析 学习笔记1 递归与分治法 复杂度计算 大数乘法

本文主要是介绍高级算法设计与分析 学习笔记1 递归与分治法 复杂度计算 大数乘法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本章的目录:

排序问题的示例与分析:递归与分治

插入排序:

类似于排序扑克牌。先把第一个元素当成已排序序列,然后把第二个纳入,用一次插入排序,然后将第三个纳入……

插入排序性能分析

大O表示上界,最差情况不外如是。

欧米噶表示下限,最好情况。

这里的上界下界一般都是确界,是刚刚好的情况,不是随便选一个特别大或者特别小的情况就可以。

中间有一杠的O,表示其上界下界都可以用一个级别的函数表示(只有系数差距,没有质变)

小o表示上界是f(n),且下界不是f(n)

对付大批量数据,还是要用分治法:

我们可以简单发现归并排序复杂度是log2n级别的。但是如果这个表达式是更加复杂的版本呢?

复杂度计算法:

方法一:猜一个式子,然后用数学归纳法验证它。

先假设在0<n<n0的时候T(n)<=cn^3,把式子带进去。

可以看到只要c随便取一个比2大的数,就可以轻松秒杀任意的n0,绝杀无解。不过n^3有点太大了吧?

cn^2+n绝无可能比cn^2小,没办法了吗?好像差距不大啊:

这里再举一个例子:

下面这种算法是

递归树法:

先写上可以确定的作为最上层的,叶子就是还不确定,要接着算的,然后就接着拆开……

主方法

注意这种方法专门针对这种形式,是这种问题的简单解法。

这样求解公式被分成了两个部分。

如果f(n)比较小(真小的那种,不能是相当,而且是n^某某次方(不是无穷小,/lgn啥的不行))那就就是以n^logb(a)为主

如果二者相当,那就是n^logb(a) * lg(n)

如果f(n)比较大且占据n^*级别优势,那就是f(n)为主。这个条件比较苛刻,还要求af(n/b) <= cf(n)  (c要小于1!,n要大)

注意这里的都是带等号的O!上下界都是这个,是很强的结论

我们举几个例子:

最后一个例子中,虽然是f(n)比较小,应该是第一种情况,但小得不够多,不构成n^*级别优势,所以不成。

三种方法中,最后这种主方法是最重要的。

大整数乘法

XY的乘法式子可以改写成两种形式:

改写成下面两种形式只需要3次乘法(原版要4次)实际上一般用1方法,先做减法比较好。

这篇关于高级算法设计与分析 学习笔记1 递归与分治法 复杂度计算 大数乘法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

Python中的可视化设计与UI界面实现

《Python中的可视化设计与UI界面实现》本文介绍了如何使用Python创建用户界面(UI),包括使用Tkinter、PyQt、Kivy等库进行基本窗口、动态图表和动画效果的实现,通过示例代码,展示... 目录从像素到界面:python带你玩转UI设计示例:使用Tkinter创建一个简单的窗口绘图魔法:用

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

Redis连接失败:客户端IP不在白名单中的问题分析与解决方案

《Redis连接失败:客户端IP不在白名单中的问题分析与解决方案》在现代分布式系统中,Redis作为一种高性能的内存数据库,被广泛应用于缓存、消息队列、会话存储等场景,然而,在实际使用过程中,我们可能... 目录一、问题背景二、错误分析1. 错误信息解读2. 根本原因三、解决方案1. 将客户端IP添加到Re

Redis主从复制实现原理分析

《Redis主从复制实现原理分析》Redis主从复制通过Sync和CommandPropagate阶段实现数据同步,2.8版本后引入Psync指令,根据复制偏移量进行全量或部分同步,优化了数据传输效率... 目录Redis主DodMIK从复制实现原理实现原理Psync: 2.8版本后总结Redis主从复制实

锐捷和腾达哪个好? 两个品牌路由器对比分析

《锐捷和腾达哪个好?两个品牌路由器对比分析》在选择路由器时,Tenda和锐捷都是备受关注的品牌,各自有独特的产品特点和市场定位,选择哪个品牌的路由器更合适,实际上取决于你的具体需求和使用场景,我们从... 在选购路由器时,锐捷和腾达都是市场上备受关注的品牌,但它们的定位和特点却有所不同。锐捷更偏向企业级和专

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

Python中列表的高级索引技巧分享

《Python中列表的高级索引技巧分享》列表是Python中最常用的数据结构之一,它允许你存储多个元素,并且可以通过索引来访问这些元素,本文将带你深入了解Python列表的高级索引技巧,希望对... 目录1.基本索引2.切片3.负数索引切片4.步长5.多维列表6.列表解析7.切片赋值8.删除元素9.反转列表