蓝桥杯备赛——DP【python】

一、小明的背包1

试题链接:https://www.lanqiao.cn/problems/1174/learning/

问题描述

输入实例

python 复制代码
5 20
1 6
2 5
3 8
5 15
3 3 

输出示例

python 复制代码
37

问题分析

这里我们要创建一个DP表,DP(i,j)表示处理到第i个物品时消耗j体积。这样我们在输入数据时可以直接进行操作。对于每一个dpij我们都可以转化为求其子问题的最优解,即返回到上一次dpi-1,我们需要注意一个特殊的值dpi-1j-w(w为第i个数的体积),我们可以由dpi-1j-w+v (v为第i个物品的价值)到达dpij,也可以由dpi-1j直接到dpij,这里就分成了两种情况,即要么选第i个物品,要么不选第i个物品。这样就形成一个dp表,我们只需要求出其中的最大值即可。

PS:对dp表还可以进行一个空间优化,每一个dpij只和dpi-1有关,所以我们只需要两个一维列表即可,每操作完一个物品,就将dp0替换成dp1


代码示例

python 复制代码
N,V=map(int,input().split())
dp=[[0]*(V+1) for _ in range(N+1)]
ans=0
for i in range(1,N+1):
    w,v=map(int,input().split())
    for j in range(V+1):
        if j-w>=0:
            dp[i][j]=max(dp[i-1][j],dp[i-1][j-w]+v)
        else:
            dp[i][j]=dp[i-1][j]
        ans=max(ans,dp[i][j])
print(ans)

空间优化后的代码

python 复制代码
N,V=map(int,input().split())
dp0=[0]*(V+1)
dp1=[0]*(V+1)
ans=0
for i in range(1,N+1):
    w,v=map(int,input().split())
    for j in range(V+1):
        if j-w>=0:
            dp1[j]=max(dp0[j],dp0[j-w]+v)
        else:
            dp1[j]=dp0[j]
        ans=max(ans,dp1[j])
    dp0=dp1.copy()
print(ans)

二、2022

试题链接:https://www.lanqiao.cn/problems/2186/learning/

问题描述


问题分析

这是一道DP问题,要三个参数,dpijk代表判断到第i个数,选择了其中j个数,和为k共有多少种情况。

对于dpijk可以分两种情况:①k>=i;这时dpijk=dpi-1j-1k-i+dpi-1jk(即选择i或不选) ②k<i;这时dpijk=dpi-1jk(想加也加不进去)

初始条件为dpi00=1,注意dp000也为1,否则dp111==0


代码示例

python 复制代码
V=2022
n=2022
dp=[[[0]*2023 for _ in range(11)] for _ in range(n+1)]
dp[0][0][0]=1
for i in range(1,n+1):
    dp[i][0][0]=1
    for j in range(1,11):
        for k in range(1,2023):
            if k>=i:
                dp[i][j][k]=dp[i-1][j-1][k-i]+dp[i-1][j][k]
            else:
                dp[i][j][k]=dp[i-1][j][k]
print(dp[2022][10][2022])
#379187662194355221

三、过河卒

试题链接:https://www.lanqiao.cn/problems/755/learning/​​​​​​

输入示例

python 复制代码
6 6 3 3

输出示例

python 复制代码
6

问题分析

对于每一个点(i,j),从起点开始到该点的不同路径为dpij,由题意可得只能从该点左边或上面到达该点,所以dpij=dpi-1j+dpij-1。注意不要出界且部分点不能走即可。


代码示例

python 复制代码
a,b,c,d=map(int,input().split())
dp=[[0]*(b+1) for _ in range(a+1)]
dp[0][0]=1
dp[c][d]=-1
he=[-2,-2,-1,-1,1,1,2,2]
sh=[-1,1,-2,2,-2,2,-1,1]
for _ in range(8):
    i=c+he[_]
    j=d+sh[_]
    if i>=0 and j>=0:
        dp[i][j]=-1
for i in range(a+1):
    for j in range(b+1):
        
        if dp[i][j]==-1:
            dp[i][j]=0
        else:
            if i>0:
                dp[i][j]+=dp[i-1][j]
            if j>0:
                dp[i][j]+=dp[i][j-1]
print(dp[a][b])
相关推荐
weelinking15 小时前
【产品】12_接入数据库——让数据永久保存
jvm·数据库·python·react.js·数据挖掘·前端框架·产品经理
程序大视界16 小时前
【Python系列课程】Python正则表达式(下):环视、命名分组与日志实战
开发语言·python·正则表达式
TickDB16 小时前
美股行情 API 接入避坑:REST 快照、WebSocket 推送、盘前盘后数据的边界
人工智能·python·websocket·行情数据 api
枫叶v.16 小时前
Agent 分层存储架构设计:从记忆方法到中间件选型
开发语言·python
水兵没月17 小时前
逆向实战小记——某ToB商城网站分析学习
python·网络爬虫
程序员小远17 小时前
Python自动化测试框架及工具详解
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
sleven fung18 小时前
MinerU与BabelDOC与KTransformers与OpenAI API库
开发语言·python·ai·langchain
小毛驴85018 小时前
spring-boot-maven-plugin,maven-compiler-plugin 功能对比
java·python·maven
萤萤七悬18 小时前
【Python笔记】AI帮实现CLI工具-使用argparse.ArgumentParser接收命令参数
开发语言·笔记·python
郑洁文19 小时前
基于Python的Web命令执行漏洞自动化检测系统
前端·python·网络安全·自动化