码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 力扣 -- 518. 零钱兑换 II(完全背包问题)


    解题步骤:

    参考代码:

    未优化代码:

    1. class Solution {
    2. public:
    3. int change(int amount, vector<int>& coins) {
    4. int n=coins.size();
    5. //多开一行,多开一列
    6. vectorint>> dp(n+1,vector<int>(amount+1));
    7. //初始化dp[0][0]=1,其它的dp[0][j]都为0,因为不存在,所以只有0种选法
    8. dp[0][0]=1;
    9. //不要把dp[0][j]剩下的值初始化成-1,曾经因初始化成-1而出错
    10. //第一列不需要初始化
    11. //填表
    12. for(int i=1;i<=n;i++)
    13. {
    14. //记得从0开始
    15. for(int j=0;j<=amount;j++)
    16. {
    17. dp[i][j]=dp[i-1][j];
    18. if(j>=coins[i-1]&&dp[i][j-coins[i-1]]!=0)
    19. {
    20. dp[i][j]+=dp[i][j-coins[i-1]];
    21. }
    22. }
    23. }
    24. //返回值
    25. return dp[n][amount];
    26. }
    27. };

    优化后代码:

    1. class Solution {
    2. public:
    3. int change(int amount, vector<int>& coins) {
    4. int n=coins.size();
    5. vector<int> dp(amount+1);
    6. //初始化
    7. dp[0]=1;
    8. //填表
    9. for(int i=1;i<=n;i++)
    10. {
    11. for(int j=coins[i-1];j<=amount;j++)
    12. {
    13. if(dp[j-coins[i-1]]!=0)
    14. {
    15. dp[j]+=dp[j-coins[i-1]];
    16. }
    17. }
    18. }
    19. //返回值
    20. return dp[amount];
    21. }
    22. };

    你学会了吗???

  • 相关阅读:
    七、构建 RESTful 服务
    第三章:人工智能深度学习教程-基础神经网络(第五节-了解多层前馈网络)
    npm最新淘宝镜像站已经更新registry(2024-04-19)
    数据库基础篇二
    (Java)递归,数组
    [Vue 配置] Vite + Vue3 项目配置和使用 NProgress
    HCIA网络基础7-VRP和命令行基础
    力扣 SQL题目
    【设计模式】Java设计模式 - 访问者模式
    [flask]统一API响应格式
  • 原文地址:https://blog.csdn.net/weixin_70056514/article/details/133531446
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号