首页 > 编程语言 >蓝桥杯备赛——DP【python】

蓝桥杯备赛——DP【python】

时间:2024-05-26 12:34:43浏览次数:18  
标签:dp1 示例 python dp0 蓝桥 range DP ans dp

一、小明的背包1

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

问题描述

输入实例

5 20
1 6
2 5
3 8
5 15
3 3 

输出示例

37

问题分析

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

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


代码示例

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)

空间优化后的代码

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问题,要三个参数,dp[i][j][k]代表判断到第i个数,选择了其中j个数,和为k共有多少种情况。

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

初始条件为dp[i][0][0]=1,注意dp[0][0][0]也为1,否则dp[1][1][1]==0


代码示例

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/​​​​​​

输入示例

6 6 3 3

输出示例

6

问题分析

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


代码示例

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])

标签:dp1,示例,python,dp0,蓝桥,range,DP,ans,dp
From: https://blog.csdn.net/weixin_71409897/article/details/139194793

相关文章

  • Python & FastAPI , 路径(路由)操作
    路径,或称“端点”或“路由”/items/foo=>指向的路径为:https://www.xxx.com/items/foo在HTTP协议中,可以使用这些“方法”中的一个(或多个)与每个路径通信:HTTP方法:POST,GET,PUT,DELETE,OPTIONS,HEAD,PATCH,TRACE在构建api时,通常使用这些特定的HTTP方法来执行特定......
  • Python & FastAPI , 路径中带参数
    如下:fromfastapiimportFastAPIapp=FastAPI()@app.get("/items/{item_id}")asyncdefread_item(item_id):return{"item_id":item_id}路径参数item_id的值将作为参数item_id传递给函数,输入http://127.0.0.1:8000/items/foo,foo为传入的参数,则其响应如下:{"it......
  • 使用树梅派搭建Golang、Python、NodeJs的开发服务器
    使用树梅派搭建Golang、Python、NodeJs的开发服务器安装系统安装rpi-imagersudoaptinstallrpi-imager打开rpi-imager烧写RaspberryPiOSLite(64-bit)系统设置好用户名、密码、wifi、ssh等信息上电修改镜像源备份/etc/apt/sources.listsudocp/etc/apt......
  • 从零开始学习 Python 3 - 玩转字符串 2:字符串格式化高阶玩法
    玩转字符串2:字符串格式化高阶玩法前言回顾:字符串格式化的三种方式高阶玩法:让你的字符串格式化更上一层楼1.格式规格迷你语言:精细控制输出格式2.自定义格式化:`__format__()`魔法方法3.格式化字符串字面值:`f"..."`的灵活运用总结公众号:人生只不过是一场投资温......
  • python pandas DataFrame-A 更新 DataFrame-B中指定列相同的数据
    假设现在有两个dataframe,分别是A和B,它们有相同的列text和label。现在想使用B的label来更新A的label,基于它们共同的text。importpandasaspd#SampleDataFramesAandBdata_A={'text':['text1','text2','text3','text4'],'label':[1......
  • python+k8s——基础练习
    列表core_api=client.CoreV1Api()#管理核心资源(Pod,Service,ConfigMap等)apps_api=client.AppsV1Api()#管理应用资源(Deployment,StatefulSet,DaemonSet等)batch_api=client.BatchV1Api()#管理批处理任务资源(Job,CronJob)rbac_api=client.RbacAuthorizati......
  • python+k8s(基础,遇到的问题)
    python+k8s(基础,遇到的问题)CoreV1Api和ApiClient的区别kubernetes.client.CoreV1Apikubernetes.client.ApiClient两者有什么区别吗kubernetes.client.CoreV1Api和kubernetes.client.ApiClient是KubernetesPython客户端库中的不同类。CoreV1Api:这是KubernetesPyt......
  • hi.选课(树形DP)
    [CTSC1997]选课(树形DP)题目描述在大学里每个学生,为了达到一定的学分,必须从很多课程里选择一些课程来学习,在课程里有些课程必须在某些课程之前学习,如高等数学总是在其它课程之前学习。现在有N......
  • python绘制多级饼图(分层饼图)
    python绘制多级饼图(分层饼图)介绍效果代码介绍多级饼图展示了数据的层次结构,其中每个级别表示数据的一个层次。我们可以使用matplotlib绘制多级饼图。效果代码importmatplotlib.pyplotasplt#示例数据outer_labels=['CategoryA','CategoryB','Categor......
  • 【使用Python3实现一个音视频播放的工具,同时实现一些自动化的功能,比如视频格式转换,视
    最近有个想法,就是使用python工具自动识别视频文件中的高潮部分#1,主要用途可以有以下几个:转换视频格式识别体育比赛中的高潮部分同样也适用识别电影中的高潮部分截取视频文件中的高潮部分,做成一个视频集锦2,搜索了一圈。使用以下组合开发了一个雏形项目。命名为movie项目。......