前端算法-零钱兑换

简介: 前端算法-零钱兑换

题目

给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1 。

输入: coins = [1, 2, 5], amount = 11
输出: 3 
解释: 11 = 5 + 5 + 1

思路一

我们这里先判断一下当前的形参amount是否为0,如果为0则直接将形参amount返回出去,如果不是我们在判断形参coins长度是否为0,如果为0则直接返回-1,我们接下来创建一个arr数组,用于记录面额从1到amount的最少硬币数,数组长度为amount+1是为了让数组的下标能直观的对应面额,然后将arr数组的首个位置默认为0,接下来使用循环,记录总金额从1到amount的最少组合次数,在循环中我们在使用一层循环进行遍历能组合的面额,在第二层循环中我们判断当前总金额是否大于等于当前循环中的面额,如果是则说明能组合,能组合的情况下我们就使用Math.min方法在已知最少组合数和当前组合最少数获取到组少组合,赋值给arr数组中的i变量数据,当循环结束后,我们判断如果arr数组中的总金额小于coins中的所有面额,那么对应的元素就一直是Infinity,我们就直接返回-1,否则我们将总金额返回出去即可

var coinChange = function(coins, amount) {
    if(amount === 0) {
        return amount
    }
    if(coins.length === 0) {
        return -1
    }
    let arr = new Array(amount+1).fill(Infinity)
    arr[0] = 0
    for(let i=1;i<=amount;i++){
        for(let j=0,len=coins.length;j<len;j++){
            if(i>=coins[j]){
                arr[i] = Math.min(arr[i],arr[i-coins[j]]+1)
            }
        }
    }
    if(arr[amount] === Infinity){
        return -1;
    }else{
       return arr[amount];
    }
};


相关文章
|
11天前
|
搜索推荐 前端开发 数据可视化
【优秀python web毕设案例】基于协同过滤算法的酒店推荐系统,django框架+bootstrap前端+echarts可视化,有后台有爬虫
本文介绍了一个基于Django框架、协同过滤算法、ECharts数据可视化以及Bootstrap前端技术的酒店推荐系统,该系统通过用户行为分析和推荐算法优化,提供个性化的酒店推荐和直观的数据展示,以提升用户体验。
|
3月前
|
移动开发 算法 前端开发
前端算法之堆排序
前端算法之堆排序
28 1
|
12天前
|
搜索推荐 前端开发 算法
基于用户画像及协同过滤算法的音乐推荐系统,采用Django框架、bootstrap前端,MySQL数据库
本文介绍了一个基于用户画像和协同过滤算法的音乐推荐系统,使用Django框架、Bootstrap前端和MySQL数据库构建,旨在为用户提供个性化的音乐推荐服务,提高推荐准确性和用户满意度。
基于用户画像及协同过滤算法的音乐推荐系统,采用Django框架、bootstrap前端,MySQL数据库
|
3月前
|
前端开发 算法
sass 公用10个mixins代码块,算法太TM重要了,前端开发要求
sass 公用10个mixins代码块,算法太TM重要了,前端开发要求
|
3月前
|
算法 前端开发
前端算法之快速排序
前端算法之快速排序
29 0
|
3月前
|
算法 前端开发 搜索推荐
前端算法之归并排序
前端算法之归并排序
25 0
|
12天前
|
数据采集 前端开发 算法
基于朴素贝叶斯算法的新闻类型预测,django框架开发,前端bootstrap,有爬虫有数据库
本文介绍了一个基于Django框架和朴素贝叶斯算法开发的新闻类型预测系统,该系统具备用户登录注册、后台管理、数据展示、新闻分类分布分析、新闻数量排名和新闻标题预测等功能,旨在提高新闻处理效率和个性化推荐服务。
|
2月前
|
前端开发 算法 JavaScript
优化算法在前端性能提升中的应用
随着互联网应用的日益复杂,前端性能优化成为开发者关注的焦点。本文探讨了优化算法在前端性能提升中的重要作用,包括对JavaScript代码的优化、资源加载的算法选择以及页面渲染的优化策略。通过合理应用优化算法,可以有效提升前端应用的性能和用户体验。
|
1月前
|
缓存 算法 前端开发
前端 JS 经典:LRU 缓存算法
前端 JS 经典:LRU 缓存算法
25 0
|
3月前
|
算法 前端开发
前端算法之基数排序
前端算法之基数排序
23 1