代码随想录算法训练营第四十四天| 518 零钱兑换 || 377 组合总和 Ⅳ

目录

518 零钱兑换 ||

377 组合总和 Ⅳ  


518 零钱兑换 ||

如果求组合数就是外层for循环遍历物品,内层for遍历背包。

class Solution {
public:int change(int amount, vector<int>& coins) {vector<int> f(amount + 10);//拼凑成总金额为i的总情况数f[0] = 1;for(int i = 0;i < coins.size();i++){for(int j = coins[i];j <= amount;j++){f[j] += f[j - coins[i]];}}return f[amount];}
};

时间复杂度O(n^m)n为amount的大小,m为coins的长度

空间复杂度O(n)

377 组合总和 Ⅳ  

 如果求排列数就是外层for遍历背包,内层for循环遍历物品。 

class Solution {
public:int combinationSum4(vector<int>& nums, int target) {vector<int>f(target + 1);f[0] = 1;for(int i = 0;i <= target;i++){for(int j = 0;j < nums.size();j++){if(i >= nums[j] && f[i] < INT_MAX - f[i - nums[j]])//否则会越界f[i] += f[i - nums[j]];}}return f[target];}
};

时间复杂度O(n^m)n为target的大小,m为nums的长度

空间复杂度O(n)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/205412.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CPU密集型和IO密集型初学习

目录 1、CPU密集型 2、IO密集型 3、CPU密集型和IO密集型的区别 4、CPU密集型和IO密集型对CPU内核之间的关系 5、核心线程数计算公式 5、扩展&#xff1a;进程和线程 小结 1、CPU密集型 CPU密集型是指计算机程序或任务在执行过程中主要依赖于中央处理器&#xff08;CPU&…

IOday5作业

使用两个线程完成两个文件的拷贝&#xff0c;分支线程1完成前一半内容拷贝&#xff0c;分支线程2完成后一半内容的拷贝&#xff0c;主线程完成资源的回收 #include<myhead.h> //定义结构体 struct file {const char* srcfile;//背拷贝文件路径const char* destfile;//拷…

浏览器的缓存策略

浏览器缓存的策略主要分为两种&#xff1a;过期机制和验证机制。 过期机制&#xff1a;是指浏览器根据资源的过期时间&#xff0c;判断是否可以直接使用缓存中的副本&#xff0c;而无需向服务器发起请求。过期时间可以通过以下两种方式设置&#xff1a; Cache-Control&#xf…

C++ STL容器与常用库函数

STL是提高C编写效率的一个利器 STL容器&#xff1a; 一、#include <vector> 英文翻译&#xff1a;vector &#xff1a;向量 vector是变长数组(动态变化)&#xff0c;支持随机访问&#xff0c;不支持在任意位置O(1)插入。为了保证效率&#xff0c;元素的增删一般应该在末尾…

【设计模式-3.1】结构型——外观模式

说明&#xff1a;本文介绍设计模式中结构型设计模式中的&#xff0c;外观模式&#xff1b; 亲手下厨还是点外卖&#xff1f; 外观模式属于结构型的设计模式&#xff0c;关注类或对象的组合&#xff0c;所呈现出来的结构。以吃饭为例&#xff0c;在介绍外观模式之前&#xff0…

你们如何看待华为的鸿蒙ArkTS语言?

ArkTS是鸿蒙生态的应用开发语言。它在保持TypeScript&#xff08;简称TS&#xff09;基本语法风格的基础上&#xff0c;对TS的动态类型特性施加更严格的约束&#xff0c;引入静态类型。同时&#xff0c;提供了声明式UI、状态管理等相应的能力&#xff0c;让开发者可以以更简洁、…

要求CHATGPT高质量回答的艺术:提示工程技术的完整指南—第 26 章:让 ChatGPT 成为你自己的提示工程师

要求CHATGPT高质量回答的艺术&#xff1a;提示工程技术的完整指南—第 26 章&#xff1a;让 ChatGPT 成为你自己的提示工程师 要让 ChatGPT 成为你自己的提示工程师&#xff0c;你需要与 ChatGPT 发起对话。你可以使用下面提供的提示示例&#xff0c;内容如下&#xff1a; 步…

画好一张规范的原理图,这些点你可要注意了!

不光是代码有可读性的说法&#xff0c;原理图也有。很多时候原理图不仅仅是给自己看的&#xff0c;也会给其它人看&#xff0c;如果可读性差&#xff0c;会带来一系列沟通问题。所以&#xff0c;要养成良好习惯&#xff0c;做个规范的原理图。此外&#xff0c;一个优秀的原理图…

【云原生-K8s】镜像漏洞安全扫描工具Trivy部署及使用

基础介绍基础描述Trivy特点 部署在线下载百度网盘下载安装 使用扫描nginx镜像扫描结果解析json格式输出 总结 基础介绍 基础描述 Trivy是一个开源的容器镜像漏洞扫描器&#xff0c;可以扫描常见的操作系统和应用程序依赖项的漏洞。它可以与Docker和Kubernetes集成&#xff0c;…

temu数据如何看:多多情报通助力商家数据选品

拼多多作为中国最大的农村电商平台&#xff0c;吸引了大量的商家和消费者。对于拼多多商家来说&#xff0c;了解市场趋势、优化产品和店铺运营、了解竞争对手等方面的数据分析至关重要。为了满足商家的需求&#xff0c;拼多多推出了多多情报通&#xff08;原名&#xff1a;多多…

批量AI写作生成器有哪些?免费的批量AI写作生成器

当今信息爆炸的时代&#xff0c;文案需求量庞大&#xff0c;传统文案写作已无法满足快速迭代的需求。批量AI写作生成器应运而生&#xff0c;成为许多行业的得力助手。在众多AI写作工具中&#xff0c;147原创助手以其批量AI写作功能和在各大平台显示原创首发的特性脱颖而出。本文…

低代码:美味膳食或垃圾食品?

一、什么是低代码 低代码开发是一种软件开发方法&#xff0c;旨在通过最小化手动编码的需求&#xff0c;使应用程序的开发变得更加快速和简单。它通常涉及使用图形界面和可视化工具&#xff0c;而不是传统的编码方法&#xff0c;以减少开发过程中的繁琐步骤。 二、低代码的优…

Metasploit在红队作战中的应用

预计更新 第一章 Metasploit的使用和配置 1.1 安装和配置Metasploit 1.2 Metasploit的基础命令和选项 1.3 高级选项和配置 第二章 渗透测试的漏洞利用和攻击方法 1.1 渗透测试中常见的漏洞类型和利用方法 1.2 Metasploit的漏洞利用模块和选项 1.3 模块编写和自定义 第三章 Me…

利用TCP通信实现文件传输和通信

前言 我们上一章已经熟悉了理论知识&#xff0c;这一章来练习一下 1.实现文件的传输 1.1 客户端 dir_client.c #include <stdio.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #include <sys/types.h> #include …

【Java用法】关于线程的创建方式,已知全网最全面的总结,七种创建线程的方式

关于线程的创建方式,已知全网最全面的总结,七种创建线程的方式 一、继承Thread,重写run方法二、实现Runnable接口,重写run方法三、lambda表达式四、使用匿名内部类创建 Thread 子类对象五、使用匿名内部类,实现Runnable接口六、实现Callable接口七、使用线程池创建线程关于…

Docker快速理解及简介

docker快速理解及简介 1.Docker为什么出现&#xff1f; 迁移一个项目时&#xff0c;运行文档、配置环境、运行环境、运行依赖包、操作系统发行版、内核等都需要重新安装配置&#xff0c;比较麻烦。 2.Docker是什么&#xff1f; Docker是基于Go语言实现的云开源项目。解决了运行…

C语言指针详解上

1 野指针 int main01(){//野指针就是没有初始化的指针,指针的指向是随机的,不可以 操作野指针//int a 0;//指针p保存的地址一定是定义过的(向系统申请过的)int *p;//野指针*p 200;printf("%d\n",*p);system("pause");return 0;}2 空指针 空指针的作用…

Linux C语言 40-进程间通信IPC之消息队列

Linux C语言 40-进程间通信IPC之消息队列 本节关键字&#xff1a;C语言 System V IPC 进程间通信 消息队列 相关库函数&#xff1a;ftok、msgget、msgsnd、msgrcv、msgctl 什么是消息队列&#xff1f; 消息队列是System V中的一种进程间通信机制&#xff08;如管道、信号量、…