当前位置: 首页 > news >正文

算法笔记(九)—— 暴力递归

暴力递归(尝试)

1. 将问题转化为规模缩小了的同类问题子问题

2. 有明确的不需要的继续递归的条件

3. 有当得到子问题结果之后的决策过程

4. 不记录每一个子问题的解

Question:经典汉诺塔问题

1. 理解清楚,基础三个圆盘的移动方式

2. 如果要移动n个圆盘,则借助右将上方n-1个圆盘,从左移动到中

3. 第n个放在右,再借助左将中n-1个圆盘,从中移动到右

4. 一直拆分下去即可

Note:给所有过程定统一标准,不用去考虑全局,只需要在当前局部下的正确性。

Question:打印一个字符串全部子序列(不用连续),包括空字符串

每个字符可以选择要和不要,递归所有可能性

Question:

先手函数F,后手函数S

先手函数(max(L+S(arr,L+1,R) , R+S(arr,L,R-1)))

后手函数:min(F(arr,L+1,R) , f(arr,L,R-1))

在暴力递归尝试中,可变参数形式越简单,可变参数个数越少,对应的尝试越好(在正确的前提下)。

http://www.lryc.cn/news/12917.html

相关文章:

  • Flask框架学习记录
  • 【Opencv 系列】 第6章 人脸检测(Haar/dlib) 关键点检测
  • 信源分类及数学模型
  • Games101-202作业1
  • Linux系统之终端管理命令的基本使用
  • 【Mongoose笔记】MQTT 服务器
  • 数据结构概述
  • 【前端】Vue3+Vant4项目:旅游App-项目总结与预览(已开源)
  • 51单片机蜂鸣器的使用
  • 算法练习-链表(二)
  • LabVIEW使用实时跟踪查看器调试多核应用程序
  • 【go语言grpc之client端源码分析二】
  • centos7安装RabbitMQ
  • node基于springboot 口腔卫生防护口腔牙科诊所管理系统
  • Linux常用命令之find命令详解
  • CMake 入门学习4 软件包管理
  • 【数据库数据乱码错误】存进去的数据乱码(???)
  • rewrite中的if、break、last
  • JavaSE-线程池(5)- 建议使用的方式
  • 城市轨道交通供电系统研究(Matlab代码实现)
  • 什么是 RESTful 风格?
  • 从业6年,对敏捷和自动化测试的一点心得
  • ThreeJS 之界面控制
  • 【查找算法】解析学习四大常用的计算机查找算法 | C++
  • Android实例仿真之一
  • 软考高级-信息系统管理师之重要工具和技术的口语化表示(最新版)
  • 基于springboot+vue的个人健康信息服务平台
  • SpringBoot2.x实战专题——SpringBoot2 多配置文件【开发环境、测试环境、生产环境】
  • 测试2:编写测试用例的方法
  • docker安装配置镜像加速器-拉取创建Mysql容器示例