【找出所有稳定的二进制数组 I】python刷题记录

R4-每日一题.

今日甚是清醒.

目录

动态规划

记忆化搜索

递推方法

组合数学

容斥原理+乘法原理

ps:

贴题解

动态规划

记忆化搜索
python 复制代码
class Solution:
    def numberOfStableArrays(self, zero: int, one: int, limit: int) -> int:
        MOD=1_000_000_007
        @cache
        def dfs(i,j,k):
            if i==0:
                return 1 if k==1 and j<=limit else 0
            if j==0:
                return 1 if k==0 and i<=limit else 0
            if k==0:
                return (dfs(i-1,j,0)+dfs(i-1,j,1)-(dfs(i-limit-1,j,1) if i>limit else 0))% MOD
            else:
                return (dfs(i,j-1,0)+dfs(i,j-1,1)-(dfs(i,j-limit-1,0) if j>limit else 0))% MOD
        ret=(dfs(zero,one,0)+dfs(zero,one,1)) % MOD
        #防止爆内存
        dfs.cache_clear()
        return ret
递推方法

就是将记忆化翻译成3维数组!

python 复制代码
class Solution:
    def numberOfStableArrays(self, zero: int, one: int, limit: int) -> int:
        MOD=1_000_000_007
        #直接上3维数组
        f=[[[0,0] for _ in range(one+1)] for _ in range(zero+1)]
        for i in range(1,min(limit,zero)+1):
            f[i][0][0]=1
        for j in range(1,min(limit,one)+1):
            f[0][j][1]=1
        for i in range(1,zero+1):
            for j in range(1,one+1):
                f[i][j][0]=(f[i-1][j][0]+f[i-1][j][1]-(f[i-limit-1][j][1] if i>limit else 0))%MOD
                f[i][j][1]=(f[i][j-1][0]+f[i][j-1][1]-(f[i][j-limit-1][0] if j>limit else 0))%MOD
        return sum(f[-1][-1])%MOD

组合数学

容斥原理+乘法原理

这是人能想出来的吗??!!

python 复制代码
class Solution:
    def numberOfStableArrays(self, zero: int, one: int, limit: int) -> int:
        MOD=1_000_000_007
        MX=1001
 
        #f[i]=i! 阶乘
        fac=[0]*MX
        fac[0]=1
        for i in range(1,MX):
            fac[i]=fac[i-1]*i%MOD
        
        #inv_f[i]=i!^-1
        inv_f=[0]*MX
        inv_f[-1]=pow(fac[-1],-1,MOD)
        for i in range(MX-1,0,-1):
            inv_f[i-1]=inv_f[i]*i%MOD
        
        #最终计算(n m)
        def comb(n,m):
            return fac[n]*inv_f[m]*inv_f[n-m]%MOD
        
        if zero>one:
            # 保证空间复杂度为 O(min(zero, one))
            zero,one=one,zero
        f0=[0]*(zero+3)
        for i in range((zero-1)//limit+1,zero+1):
            f0[i]=comb(zero-1,i-1)
            for j in range(1,(zero-i)//limit+1):
                f0[i]=(f0[i]+(-1 if j%2 else 1)*comb(i,j)*comb(zero-j*limit-1,i-1))%MOD
        
        ret=0
        for i in range((one-1)//limit+1,min(one,zero+1)+1):
            f1=comb(one-1,i-1)
            for j in range(1,(one-i)//limit+1):
                f1=(f1+(-1 if j %2 else 1)*comb(i,j)*comb(one-j*limit-1,i-1))%MOD
            ret=(ret+(f0[i-1]+f0[i]*2+f0[i+1])*f1)%MOD
        return ret

灵神真的厉害!

ps:

1.

python 复制代码
#防止整数溢出     
MOD=1_000_000_007
%MOD   
python 复制代码
#记忆化搜索
@cache
python 复制代码
#防止爆内存
dfs.cache_clear()

2.

​​​​​​​3.

刷完后再润灵神题单(争取开学前干完?!)

灵神题单

相关推荐
cjp5605 小时前
009.UG二次开发,任务环境草图优化3(高级功能生成直线)
算法
芝士就是力量啊 ೄ೨5 小时前
Python如何编写一个简单的类
开发语言·python
样例过了就是过了5 小时前
LeetCode热题100 分割等和子集
数据结构·c++·算法·leetcode·动态规划
胖虎喜欢静香5 小时前
从零到一快速实现 Mini DeepResearch
人工智能·python·开源
逻辑驱动的ken5 小时前
Java高频面试考点18
java·开发语言·数据库·算法·面试·职场和发展·哈希算法
MoonBit月兔5 小时前
「Why MoonBit 」第一期——Singularity Note AI 学习助手
开发语言·人工智能·moonbit
qq_392690665 小时前
Redis怎样应对Redis集群整体宕机带来的雪崩
jvm·数据库·python
木木_王5 小时前
嵌入式Linux学习 | 数据结构 (Day05) 栈与队列详解(原理 + C 语言实现 + 实战实验 + 易错点剖析)
linux·c语言·开发语言·数据结构·笔记·学习
Muyuan19985 小时前
22.让 RAG Agent 更像真实产品:聊天页面优化、PDF 上传、知识库重建与检索片段展示
python·django·pdf·fastapi
冷雨夜中漫步5 小时前
Claude Code源码分析——Claude Code Agent Loop 详细设计文档
java·开发语言·人工智能·ai