leetcode-python动态规划题入门

简介: 关于动态规划,提到这个词,可能很多刷过题的测试都会感到头疼,这个难度真的是高出其他题型至少半个次元,我也不例外,要不是其他题型基本都刷光了,也不会来啃动态的题。

周六,一个简单的早上我简单的做了一道简单难度的动态规划题,这给大家简单说说,诸如上台阶的多种方法,股票买入的最佳机会,黑瞎子掰苞米的最佳收手时间,打家劫舍的 经典题型,这次的题也差不多。微信图片_20220615125937.png相信题意很简单,栅栏的柱子数 和 涂料数 都给你,让你求出一共多少种图的方法,其中有个条件,就是同一种颜色的柱子最多只能2个。也就是说 你可以:黄黄红,但是不可以黄黄黄。

针对这道题,我们可能一开始没啥思路,这里教一个小技巧,先把影响咱思维的条件删掉,看看有啥思路。也就是说,我们去掉同一种颜色柱子最多只能2根的这个设定。来考虑,那么就简单了。排列组合嘛。

假设5个柱子,3个颜色。那么每个柱子都可以涂3种情况,一共5根。那最终结果所有情况就是:3*3*3*3*3  = 3的5次方。很简单就有了主体思路,然后再加上限制条件,就是不能涂超过2根一样颜色的设定。假设只有1根 ,那么简单了。就是 3种颜色 3种结果假设只有2根,那么因为不触碰到设定最多2根所以也简单。就是3*3种结果假设有3根,这个时候才开始要考虑。前俩根的所有情况一共是 3*3 种,那么第三根呢?它有几种可以涂的情况呢?它可以这么考虑,要么只要不和第二根颜色相同,要么不和第一根颜色相同,这俩种情况都铁定不会触犯限制。不管你颜色一不一样,反正第三根满足不和第一根 或 第二根相同就好。现在让我们来看下一共的可能情况:

三根柱子:A B C

三种颜色:红 黄 蓝

A   B  C

红 红  (黄/蓝)

红 黄  (红/黄/蓝)

红 蓝  (红/黄/蓝)

黄 红  (红/黄/蓝)

黄 黄  (红/蓝)

黄 蓝  (红/黄/蓝)

蓝 红  (红/黄/蓝)

蓝 黄  (红/黄/蓝)

蓝 蓝  (红/黄)

所以结果很明显了。我们要么可以用加法观念,要么用减法观念:

3根柱子的最终结果=加法规律: 只有1根时的总结果数 * (颜色数-1)+只有2根时的总结果数*(颜色数-1)

减法规律:

3根无视规则的总结果数 - 颜色数 (不符合动态规划题意,抛弃)

给大家看一下加法观念的 代码:微信图片_20220615130206.png

这里 对 n 柱子数=0 / 1 /2 的时候 直接写死了返回值。

把最终所有的情况放进了 列表dp中(为啥叫dp?别问,大佬们都这么写)

最后返回dp最后一个元素就是最终结果了。


关于动态规划的窍门:

动态规划必然有一个列表存放 最终不同阶梯的最终结果。记住,每个结果,都是由前面最贴近的n个结果 演化出来的。也就是说你想知道 10个柱子有多少结果,你就必须知道8个柱子的结果 和9个柱子的结果。你想知道 8个柱子的结果,你就必须知道 6个柱子和7个柱子的结果。依次往前逆推,推到第一二个结果为止,这最开始的结果,你一定是闭眼睛都能知道的答案,这就是动态规划的主体思维。具体往前要推算多少种,那要看题,本题中说不能三根柱子一个颜色,那么就是需要考虑前面2个柱子。如果说不能五个一个颜色,那么你就要考虑前面4个柱子了。

如果能理解我上述所说的技巧。那么恭喜你,那些个bat等一线大厂的测试开发面试算法题,难度最复杂的题目中之一的动态规划,你可以无忧了。

所谓算法,其实考的不是你的代码水平,而是脑筋急转弯,看你灵活不灵活,对于我们普通人来说,天下算法就这么几十种题型,每种的核心解决思路我全背下来,不怕去不了bat大厂当测开。


相关文章
|
2月前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
345 7
|
3月前
|
测试技术 开发者 Python
Python单元测试入门:3个核心断言方法,帮你快速定位代码bug
本文介绍Python单元测试基础,详解`unittest`框架中的三大核心断言方法:`assertEqual`验证值相等,`assertTrue`和`assertFalse`判断条件真假。通过实例演示其用法,帮助开发者自动化检测代码逻辑,提升测试效率与可靠性。
361 1
|
2月前
|
Cloud Native 算法 API
Python API接口实战指南:从入门到精通
🌟蒋星熠Jaxonic,技术宇宙的星际旅人。深耕API开发,以Python为舟,探索RESTful、GraphQL等接口奥秘。擅长requests、aiohttp实战,专注性能优化与架构设计,用代码连接万物,谱写极客诗篇。
Python API接口实战指南:从入门到精通
|
2月前
|
存储 Java 调度
Python定时任务实战:APScheduler从入门到精通
APScheduler是Python强大的定时任务框架,通过触发器、执行器、任务存储和调度器四大组件,灵活实现各类周期性任务。支持内存、数据库、Redis等持久化存储,适用于Web集成、数据抓取、邮件发送等场景,解决传统sleep循环的诸多缺陷,助力构建稳定可靠的自动化系统。(238字)
546 1
|
3月前
|
调度 数据库 Python
Python异步编程入门:asyncio让并发变得更简单
Python异步编程入门:asyncio让并发变得更简单
214 5
|
3月前
|
数据采集 存储 XML
Python爬虫入门(1)
在互联网时代,数据成为宝贵资源,Python凭借简洁语法和丰富库支持,成为编写网络爬虫的首选。本文介绍Python爬虫基础,涵盖请求发送、内容解析、数据存储等核心环节,并提供环境配置及实战示例,助你快速入门并掌握数据抓取技巧。
|
3月前
|
大数据 数据处理 数据安全/隐私保护
Python3 迭代器与生成器详解:从入门到实践
简介:本文深入解析Python中处理数据序列的利器——迭代器与生成器。通过通俗语言与实战案例,讲解其核心原理、自定义实现及大数据处理中的高效应用。
166 0
|
3月前
|
存储 缓存 安全
Python字典:从入门到精通的实用指南
Python字典如瑞士军刀般强大,以键值对实现高效数据存储与查找,广泛应用于配置管理、缓存、统计等场景。本文详解字典基础、进阶技巧、实战应用与常见陷阱,助你掌握这一核心数据结构,写出更高效、优雅的Python代码。
93 0
|
4月前
|
数据挖掘 数据处理 C++
Python Lambda:从入门到实战的轻量级函数指南
本文通过10个典型场景,详解Python中Lambda匿名函数的用法。Lambda适用于数据处理、排序、条件筛选、事件绑定等简洁逻辑,能提升代码简洁性和开发效率。同时提醒避免在复杂逻辑中过度使用。掌握Lambda,助你写出更高效的Python代码。
234 0
|
4月前
|
数据采集 Web App开发 JSON
Python爬虫基本原理与HTTP协议详解:从入门到实践
本文介绍了Python爬虫的核心知识,涵盖HTTP协议基础、请求与响应流程、常用库(如requests、BeautifulSoup)、反爬应对策略及实战案例(如爬取豆瓣电影Top250),帮助读者系统掌握数据采集技能。
346 0

推荐镜像

更多