砝码称重 python题解

1.题目描述

题目链接:“蓝桥杯”练习系统

2.解题思路

动态规划

dp[i]:选择前i个砝码

dp[i][j]:前i个砝码可以称出重量j

dp[i][j] = 0 表示前i个砝码不可以称出重量j

dp[i][j] = 1 表示前i个砝码可以称出重量j

3. 代码实现

n = int(input())
w = list(map(int,input().split()))
w = [0] +w
dp = [[0]*(sum(w)+1) for _ in range(n+1)]
dp[0][0] = 1

for i in range(1,n+1):
    for j in range(sum(w)+1):
        if dp[i-1][j] == 1:
            dp[i][j] = 1
            dp[i][j+w[i]] = 1
            dp[i][abs(j-w[i])] = 1
print(sum(dp[n])-1)

 4. 代码解读

dp[0][0]:0个砝码可以称出重量0

sum(w) 表示最多可以称出的重量

for i in range(1,n+1) 表示循环选择前i个砝码

for j in range(sum(w)+1) 表示循环验证前i个砝码能否称出重量j

  if dp[i-1][j] == 1: 如果前i-1个砝码可以称出重量j,

① 那么前i个砝码一定也可以称出重量j,即不将第i个砝码放在天平上,所以dp[i][j] = 1

② 第i个砝码放在天平上,分两种情况:

        · 和前i-1个砝码放在同一侧,可称出重量j+w[i],则dp[i][j+w[i]] = 1

        · 和前i-1个砝码放在不同侧,可称出重量abs(j-w[i]),则dp[i][abs(j-w[i])] = 1

 sum(dp[n])-1:sum(dp[n])表示将n个砝码可称出重量的个数加起来,减一表示除去dp[n][0],即除去n个砝码都不放在天平上的情况。

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OD流水线是一种用于目标检测的深度学习模型,主要用于在图像或视频中识别和定位物体。它通过将输入图像或视频分成小块,并对每个块进行分类和定位,从而实现目标检测的功能。 Python题解是指使用Python编程语言来解决OD流水线中的问题。Python是一种简单易学、功能强大的编程语言,因其易读性和丰富的库而受到广泛应用。 在OD流水线的Python题解中,一般会使用相关的Python库和工具来实现目标检测的各个步骤。首先,需要使用OpenCV或PIL库加载和处理输入的图像或视频数据。然后,需要使用一种深度学习框架,例如TensorFlow或PyTorch,加载预训练的OD模型。接下来,将输入的图像数据传入模型中进行推理,并获取每个目标的类别和位置信息。最后,可以根据需要对检测到的目标进行后续处理,如绘制边界框、标注类别等。 在OD流水线的Python题解中,还可以使用其他辅助工具和技术来提升检测性能。例如,可以使用图像增强技术来提高输入图像的质量,或者使用非极大值抑制算法来去除重叠的边界框。此外,还可以根据具体应用场景进行模型微调或优化,以提高模型在特定数据集上的检测准确率和速度。 总之,OD流水线的Python题解是一种使用Python编程语言实现目标检测的方法。通过使用相关的Python库和工具,结合深度学习模型和其他辅助技术,可以实现高效、精确的目标检测功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值