题解 | #兑换零钱(一)#

兑换零钱(一)

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

import java.util.*;


public class Solution {
    /**
     * 最少货币数
     * @param arr int整型一维数组 the array
     * @param aim int整型 the target
     * @return int整型
     */
    // 背包问题!
    public int minMoney (int[] arr, int aim) {
        if(aim < 1) return 0;
        int[] dp = new int[aim+1]; // dp[i] 表示当钱的总数为 i 时,最少需要的钞票数!
        Arrays.fill(dp,aim +1);
        dp[0] = 0;
        for(int i = 1; i <= aim; i++){
            for(int kind : arr){
                if(i >= kind){
                    dp[i] = Math.min(dp[i],dp[i-kind]+1);
                }
            }
        }
        return dp[aim] > aim ? -1 : dp[aim];
    }
}
全部评论

相关推荐

06-17 00:26
门头沟学院 Java
程序员小白条:建议换下项目,智能 AI 旅游推荐平台:https://github.com/luoye6/vue3_tourism_frontend 智能 AI 校园二手交易平台:https://github.com/luoye6/vue3_trade_frontend GPT 智能图书馆:https://github.com/luoye6/Vue_BookManageSystem 选项目要选自己能掌握的,然后最好能自己拓展的,分布式这种尽量别去写,不然你只能背八股文了,另外实习的话要多投,尤其是学历不利的情况下,多找几段实习,最好公司title大一点的
无实习如何秋招上岸
点赞 评论 收藏
分享
仁者伍敌:牛子这些人还会点一个自动回复,boss都不带回复的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务