三、递归树分析法

1 问题

在这里插入图片描述

2 解决思路

使用递归树猜想一个上界,使用归纳法证明上界也是下界。

2.1 使用递归树(recursion tree)猜想结论(不严谨)

使用递归树两点:1⃣️逐行展开;2⃣️逐行相加;

逐行展开

本质上是分解问题,每个非叶子结点表示分解+合并问题所付出的代价,叶子结点表示解决边界问题所付出的代价。
在这里插入图片描述

逐层求和

这里要注意,除去非叶子结点,每一层的和呈现出等比数列性质,计算整个代价T(n)T(n)T(n)本质上就是分解(合并)问题付出的代价+解决递归边界付出的代价。

Case1:

分解问题的代价:
在这里插入图片描述
在这里插入图片描述
解决递归边界的代价:
Θ(nlogba)\Theta(n^{log_ba})Θ(nlogba)
取多项式最高次项,因此T(n)=O(nlogba)T(n) = O(n^{log_ba})T(n)=O(nlogba);

Case2:

分解问题的代价:
在这里插入图片描述
解决递归边界的代价:
Θ(nlogba)\Theta(n^{log_ba})Θ(nlogba)
取多项式最高次项,因此T(n)=O(nlogbalogbn)T(n) = O(n^{log_ba}log_bn)T(n)=O(nlogbalogbn);

Case3:

分解问题的代价:
根据假设容易得到
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
上面的不等号是渐进成立的,所以为了保证对每一个nnn都成立,对于前有限的nnn,要加上每一个都要加上一个足够大的常数,因此有下面的式子。
在这里插入图片描述
解决递归边界的代价:
Θ(nlogba)\Theta(n^{log_ba})Θ(nlogba)
取多项式最高次项,因此T(n)=O(f(n))T(n) = O(f(n))T(n)=O(f(n));

2.2 使用归纳法证明结论(严谨)

上面的递归树分析只是大概得到了一个上界,下面使用数学归纳发证明上届也是下界。

Case1:

在这里插入图片描述

Case2:

在这里插入图片描述

Case3:

在这里插入图片描述

3 结论

  1. 先使用非严谨的形式分析、猜想,然后用数学归纳法证明,这个思路贯穿整个导论一书;
  2. 主定理由递归树推出,很多情形不符合主定理的假设,但是递归树+归纳法仍然可以解决,所以整个过程最有价值的是这套分析、证明方法,而非主定理。
  3. 上面在使用归纳法证明时,渐进符号的威力惊艳了我!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/420769.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

html5input表单标签新属性

初探h5一,h5 新增表单类型二,新增表单属性三,code demo一,h5 新增表单类型 •email 邮箱地址•url 网络地址•number 数字框•range 滑块•Date pickers (date, month, week, time, datetime, datetime-local) 日期时间框•search…

关于java的JIT知识

1.JIT的工作原理图 工作原理 当JIT编译启用时(默认是启用的),JVM读入.class文件解释后,将其发给JIT编译器。JIT编译器将字节码编译成本机机器代码。 通常javac将程序源码编译,转换成java字节码,JVM通过解释…

Storage 使用

关于web项目数据存储1. 存储种类2. localStorage/sessionStorage2.1 概念2.2 api的使用3. 学生curd测试localStorage针对客户端存储讲 ——storage1. 存储种类 1. 分为服务器端和客户端的存储 2. 服务器端:1. 内存存储(临时)application session request pageConte…

spring 基于xml方式配置aop

目录什么是aop模拟aop配置什么是aop 什么是aop 作用 在程序运行期间,在不修改源码的情况下对方法进行功能增强 优势 减少重复代码 提高开发效率 并且便于开发2.aop关键概念 模拟aop 目标接口 package com.lovely.proxy.aop;public interface TargetInterface …

3389爆破DUBrute_2.1

3389专业爆破 DUBrute_2.1.zip http://pan.baidu.com/s/1pJE0t5L转载于:https://www.cnblogs.com/lieyan/p/3859696.html

h5 server send event(sse)

1. sse概述 概念: H5支持使用JS脚本不间断的访问服务器(推送)轮询: 页面使用js的定时器,定时发送请求查询最新数据 使用js将最新数据加载至页面 每发送一次数据,需要建立新的连接 时间间隔由客户端决定 优点:不需要刷新页面、实…

sublime text3下BracketHighlighter的配置方法

st3的配置方法和st2是有区别的,所以网上搜索到的方法大多不能用,我google之后总结了一下。 一、 1、在st3中按preferences-->package settings-->Bracket highlighter-->Bracket settings-Default打开配置文件。 2、将配置文件信息全选复制一份…

利用spring注解创建bean

spring注解spring 原始注解1.1 Component注解1.2 Controller,Service,Repository同上1.3 注解方式依赖注入spring 新注解1. 用来解析配置类&#xff0c;利用配置类替代xml注解代替了xml的繁琐配置 spring 原始注解 1.1 Component注解 <!--spring 使用注解创建对象 compone…

文本分类--普通分类

1 基本概念 文本分类 文本分类&#xff08;text classification&#xff09;&#xff0c;指的是将一个文档归类到一个或多个类别的自然语言处理任务。文本分类的应用场景非常广泛&#xff0c;包括垃圾邮件过滤、自动打标等任何需要自动归档文本的场合。 文本分类在机器学习中属…

linux 烧写(1)

第一部分: 一、BootLoader的概念 BootLoader是系统加电启运行的第一段软件代码&#xff0e;回忆一下PC的体系结构我们可以知道&#xff0c;PC机中的引导加载程序由BIOS&#xff08;其本质就是一段固件程序&#xff09;和位于硬盘MBR中的引导程序一起组成。BIOS在完成硬件检测和…

利用websocket实现一对一聊天

一对一聊天websocket1. 效果展示2. 业务分析&#xff08;逻辑展示...&#xff09;3. 技术点功能 即时发送消息||随时发送消息历史消息显示已读未读状态 1. 效果展示 由于没做登录&#xff0c;就以jack和rose两人聊天 两人可相互发消息 持续输出. . 当只有jack在线时 嘤…