【DP】个人练习-Leetcode-3129. Find All Possible Stable Binary Arrays I

题目链接:https://leetcode.cn/problems/find-all-possible-stable-binary-arrays-i/description/

题目大意:给出三个数zero, one, limit,求满足以下条件的数组的数目:

  • 数组中有zero0one1
  • 任何长度大于等于limit+1的子数组中都必须包含01

思路:刚开始想的是往zero0里插入one1,找方案数。但不知道怎么满足第二个条件。一看题解是DP,昏了。还是三重DP,这哪想得出来。

不过看了题解后还是比较清晰的,毕竟重点是搞清楚状态转移方程。

dp0[i][j]是包含i0j1且以0结尾的合法的长度为i+j的数组的数目;dp1[i][j]是包含i0j1且以1结尾的合法的长度为i+j的数组的数目。那么显然结果就是dp0[zero][one] + dp1[zero][one]

那么如何转移状态呢?
dp0[i][j]数组是以0结尾的,那么把这个0还回去,找上一个状态。显然要从dp0[i-1][j]dp1[i-1][j]来找,因为上一个数组必然是包含i-10j1的。

对于dp1[i-1][j],这是OK的,因为这时上一个数组的结尾是1,当前数组结尾是0,必然可以直接转移,全部加上。

对于dp0[i-1][j],上一个数组结尾为0,那么要排除这种情况:前面已经连续出现了limit0(包括上一个数组的结尾0),那么在这一连串0之前必然是一个1(否则上一个数组就已经不合法了)。这种情况的数目是dp1[i-limit-1][j]。其他的可以安全加上。

因此状态转移是这样的:

				dp0[i][j] = dp1[i-1][j] + dp0[i-1][j];if (i > limit) {dp0[i][j] -= dp1[i-limit-1][j];}dp0[i][j] = (dp0[i][j] % MOD + MOD) % MOD;

那么dp1[i][j]的转移,就是把ij对调一下。

				dp1[i][j] = dp0[i][j-1] + dp1[i][j-1];if (j > limit) {dp1[i][j] -= dp0[i][j-limit-1];}dp1[i][j] = (dp1[i][j] % MOD + MOD) % MOD;

然后考虑边界情况,刚开始时应该把dp0[i][0]i <= limit && i <= zero时都置为1,因为这时只有1种方法,就是全0,并且合法。对于dp1[0][j]同理。

至于dp0[0][j]dp1[i][0]在任何时候都是不合法的,因为违背了定义要以0或者1结尾,这些置0即可。

完整代码

class Solution {
public:int numberOfStableArrays(int zero, int one, int limit) {const int MOD = 1000000007;vector<vector<int>> dp0(zero+1, vector<int>(one+1, 0));vector<vector<int>> dp1(zero+1, vector<int>(one+1, 0));for (int i = 0; i <= min(limit, zero); i++)dp0[i][0] = 1;for (int j = 0; j <= min(limit, one); j++)dp1[0][j] = 1;for (int i = 1; i <= zero; i++) {for (int j = 1; j <= one; j++) {dp0[i][j] = dp1[i-1][j] + dp0[i-1][j];if (i > limit) {dp0[i][j] -= dp1[i-limit-1][j];}dp0[i][j] = (dp0[i][j] % MOD + MOD) % MOD;dp1[i][j] = dp0[i][j-1] + dp1[i][j-1];if (j > limit) {dp1[i][j] -= dp0[i][j-limit-1];}dp1[i][j] = (dp1[i][j] % MOD + MOD) % MOD;}}return (dp0[zero][one] + dp1[zero][one]) % MOD;}
};

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

使用java分别输出二叉树的深度遍历和广度遍历

代码功能 这段Java代码定义了一个二叉树&#xff0c;并实现了两种遍历方法&#xff1a;深度优先搜索&#xff08;DFS&#xff09;和广度优先搜索&#xff08;BFS&#xff09;。通过DFS&#xff0c;代码从根节点开始&#xff0c;优先访问子节点&#xff0c;直至最深的节点&…

常用的十款文件加密软件分享|2024办公文件怎么加密?赶快码住!

在现代办公环境中&#xff0c;数据安全和隐私保护变得尤为重要&#xff0c;尤其是随着远程办公、跨平台协作的普及&#xff0c;文件的加密需求大大增加。为了保障敏感信息的安全性&#xff0c;选择合适的加密软件成为必不可少的一步。本文将为大家推荐2024年常用的十款文件加密…

‌视频画面添加滚动字幕剪辑:提升观众体验的创意技巧

在视频制作中&#xff0c;字幕不仅是传达信息的重要工具&#xff0c;也是提升观众体验的关键元素。本文将探讨如何在视频画面中添加滚动字幕剪辑&#xff0c;以提升观众的观看体验。 1打开软件&#xff0c;在功能栏里切换到“任务剪辑”版块上 2添加原视频导入到表格里&#x…

简单花20分钟学会top 命令手册 (linux上的任务管理器)

1. 介绍 top 是一个常用的 Linux 命令行工具&#xff0c;用于实时监视系统资源和进程的运行情况。用户可以通过 top 命令查看系统的 CPU 使用率、内存占用情况、进程列表等重要信息&#xff0c;帮助快速了解系统运行状态并进行性能监控。该工具可以认为相当于windows上的任务管…

探索Theine:Python中的AI缓存新贵

文章目录 探索Theine&#xff1a;Python中的AI缓存新贵背景&#xff1a;为何选择Theine&#xff1f;Theine是什么&#xff1f;如何安装Theine&#xff1f;简单的库函数使用方法场景应用场景一&#xff1a;Web应用缓存场景二&#xff1a;分布式系统中的数据共享场景三&#xff1…

【DFDT】DFDT: An End-to-End DeepFake Detection Framework Using Vision Transformer

文章目录 DFDT: An End-to-End DeepFake Detection Framework Using Vision Transformerkey points贡献方法补丁提取和嵌入基于注意力的补丁选择多流transformer块多尺度分类器实验DFDT: An End-to-End DeepFake Detection Framework Using Vision Transformer 会议/期刊:App…

Java 函数式编程(1 万字)

此笔记来自于B站黑马程序员 good Java 历史版本及其优势 函数式编程, Stream API 一.函数伊始函数、函数对象 函数对象 行为参数法 延迟执行 a-lambda b-方法引用 复习小测 Math::random () -> Math.random()Math::sqrt (double number) -> Math.sqrt(number)Student:…

光路科技TSN交换机:驱动自动驾驶技术革新,保障高精度实时数据传输

自动驾驶技术正快速演进&#xff0c;对实时数据处理能力的需求激增。光路科技推出的TSN&#xff08;时间敏感网络&#xff09;交换机&#xff0c;在比亚迪最新车型中的成功应用&#xff0c;显著推动了这一领域的技术进步。 自动驾驶技术面临的挑战 自动驾驶系统需整合来自雷达…

揭秘!尤雨溪成立的VoidZero如何改变前端世界

前言 Vue和Vite之父尤雨溪宣布成立公司 VoidZero&#xff0c;目前已经融资3200万。这篇文章欧阳将带你了解VoidZero是如何改变javascript的世界&#xff01; 加入欧阳的高质量vue源码交流群、欧阳平时写文章参考的多本vue源码电子书 痛点1: 工具太多&#xff0c;学不动 公司…

Library介绍(四)

标准单元描述 标准单元主要由以下几个部分构成&#xff0c;分别是引脚电容、power、timing组成。其中引脚电容主要包含input/output pin的电容值。 power主要包含每个pin的leakage power和internal power。 timing主要包括cell的input pin到output pin的rise delay和fall del…

Shuffle Net系列详解 (1) Shuffle Net论 V1论文理论部分详解

Shuffle Net 系列 论文精讲部分0.摘要1. 引文2. 相关工作3. Approach方法3.1 Channel Shuffle for Group Convolutions 通道重排针对分组卷积3.2 模型块Blocka Blockb Blockc Block 3.3 模型整体架构 4 实验5 总结 论文精讲部分 本专栏致力于深度剖析轻量级模型相关的学术论文…

浏览器书签的同步和备份工具Elysian

什么是 Elysian &#xff1f; Elysian 是一个自托管工具&#xff0c;用于将您经常使用的书签从浏览器的书签工具栏备份到您的家庭实验室。包括服务和浏览器插件两部分。 Elysian 主要专注于将您浏览器的常用书签备份到您家庭实验室中运行的 Elysian 服务器。浏览器插件使用 chr…

利用1688商品数据洞察市场:优化策略,提升业绩

对1688商品通过API接口的数据进行详细分析&#xff0c;可以帮助商家更好地了解商品的市场表现、用户需求及行为&#xff0c;从而优化商品供应和销售策略。以下是对1688商品数据的详细分析&#xff0c;包括需要分析的具体数据、分析过程及结果、以及基于分析结果的建议。 一、需…

【日记】我不想调回去啊啊啊(341 字)

正文 新电脑不知道为什么有时键盘会突然没反应。 今天没有客户&#xff0c;工作上几乎没什么可说的。唯一听到的消息&#xff0c;似乎是我可能不久之后就要被调回去&#xff0c;因为市分行有人要人事调动。 救命啊&#xff01;我不想回市分行。在下面吃住都比市分行好&#xff…

C语言之扫雷小游戏(完整代码版)

说起扫雷游戏&#xff0c;这应该是很多人童年的回忆吧&#xff0c;中小学电脑课最常玩的必有扫雷游戏&#xff0c;那么大家知道它是如何开发出来的吗&#xff0c;扫雷游戏背后的原理是什么呢&#xff1f;今天就让我们一探究竟&#xff01; 扫雷游戏介绍 如下图&#xff0c;简…

鸿蒙开发之ArkUI 界面篇 二十四 计数器案例

计数器案例&#xff0c;点击’-‘按钮&#xff0c;数字减少1&#xff0c;点击啊‘’按钮&#xff0c;数字加一 分析&#xff1a;这里需要三个组件&#xff0c;外层容器是Row&#xff0c;从左往右的组件分别是ButtonTextButton&#xff0c;涉及到修改更新界面&#xff0c;变量需…

【PGCCC】在 Postgres 上构建图像搜索引擎

我最近看到的最有趣的电子商务功能之一是能够搜索与我手机上的图片相似的产品。例如&#xff0c;我可以拍一双鞋或其他产品的照片&#xff0c;然后搜索产品目录以查找类似商品。使用这样的功能可以是一个相当简单的项目&#xff0c;只要有合适的工具。如果我们可以将问题定义为…

点评项目-4-隐藏敏感信息、使用 redis 优化登录业务

一、隐藏敏感信息 之前我们对 /user/me 路径&#xff0c;直接返回了登录的所有用户信息&#xff0c;其中的 passward 等敏感信息也会被返回到前端&#xff0c;这是很危险的&#xff0c;故我们需要选择性的返回用户信息&#xff0c;隐藏敏感用户信息 我们可以创建一个 UserDTO…

Linux环境变量及命令行参数

目录 一、环境变量的概念和基本命令 二、环境变量的组织结构及获取环境变量的方式 &#xff08;1&#xff09;组织结构 &#xff08;2&#xff09;获取环境变量 命令行第三个参数 通过第三方变量environ获取 通过系统调用getenv获取 三、命令行参数 一、环境变量的概念和…

ORM框架简介

什么是ORM&#xff1f; ORM&#xff08;Object-Relational Mapping&#xff0c;对象关系映射&#xff09;是一种编程技术&#xff0c;用于在关系数据库和对象程序语言之间转换数据。ORM框架允许开发者以面向对象的方式来操作数据库&#xff0c;而不需要编写复杂的SQL语句。简单…