题解 | #换钱的最少货币数#

换钱的最少货币数

http://www.nowcoder.com/practice/3911a20b3f8743058214ceaa099eeb45

  1. 二维dp
    dp数组的含义:用前i个硬币,能凑成j元的最小硬币个数
    #
    # 最少货币数
    # @param arr int整型一维数组 the array
    # @param aim int整型 the target
    # @return int整型
    #
    class Solution:
     def minMoney(self , arr , aim ):
         # write code here
         dp = [[i for i in range(aim+1)] for _ in range(len(arr)+1)]
         if aim <= 0 or not arr:
             return 0
    
    
    
    for j in range(len(dp[0])):
        dp[0][j] = float("inf")
    for i in range(len(dp)):
        dp[i][0] = 0

    for i in range(1, len(dp)):
        for j in range(1, len(dp[0])):
            if j-arr[i-1] >= 0:                    
                dp[i][j] = min(dp[i][j-arr[i-1]] + 1, dp[i-1][j])
            else:
                dp[i][j] = dp[i-1][j]

    if dp[-1][-1] == float("inf"):
        return -1
    else:
        return dp[-1][-1]
2. 状态压缩至一维

最少货币数

@param arr int整型一维数组 the array

@param aim int整型 the target

@return int整型

class Solution:
def minMoney(self , arr , aim ):
# write code here
dp = [i for i in range(aim+1)]
if aim <= 0 or not arr:
return 0
for i in range(len(dp)):
dp[i] = float("inf")
dp[0] = 0

    for i in range(len(arr)):
        for j in range(1, len(dp)):
            if j-arr[i-1] >= 0:                    
                dp[j] = min(dp[j-arr[i-1]] + 1, dp[j])
            else:
                dp[j] = dp[j]

    if dp[-1] == float("inf"):
        return -1
    else:
        return dp[-1]

```

全部评论

相关推荐

11-04 14:10
东南大学 Java
_可乐多加冰_:去市公司包卖卡的
点赞 评论 收藏
分享
评论
点赞
收藏
分享
正在热议
# 25届秋招总结 #
440928次浏览 4493人参与
# 春招别灰心,我们一人来一句鼓励 #
41537次浏览 524人参与
# 阿里云管培生offer #
119916次浏览 2219人参与
# 地方国企笔面经互助 #
7930次浏览 18人参与
# 同bg的你秋招战况如何? #
75751次浏览 552人参与
# 虾皮求职进展汇总 #
114497次浏览 885人参与
# 北方华创开奖 #
107325次浏览 599人参与
# 实习,投递多份简历没人回复怎么办 #
2454159次浏览 34849人参与
# 实习必须要去大厂吗? #
55696次浏览 960人参与
# 提前批简历挂麻了怎么办 #
149839次浏览 1977人参与
# 投递实习岗位前的准备 #
1195754次浏览 18547人参与
# 你投递的公司有几家约面了? #
33181次浏览 188人参与
# 双非本科求职如何逆袭 #
661963次浏览 7394人参与
# 如果公司给你放一天假,你会怎么度过? #
4734次浏览 55人参与
# 机械人春招想让哪家公司来捞你? #
157606次浏览 2267人参与
# 如果你有一天可以担任公司的CEO,你会做哪三件事? #
11402次浏览 275人参与
# 发工资后,你做的第一件事是什么 #
12447次浏览 61人参与
# 工作中,努力重要还是选择重要? #
35638次浏览 384人参与
# 参加完秋招的机械人,还参加春招吗? #
20093次浏览 240人参与
# 我的上岸简历长这样 #
451937次浏览 8088人参与
# 实习想申请秋招offer,能不能argue薪资 #
39248次浏览 314人参与
# 非技术岗是怎么找实习的 #
155855次浏览 2120人参与
牛客网
牛客企业服务