当前位置: 首页 > article >正文

【蓝桥杯速成】| 17.完全背包(一维easy版)

题目一:爬楼梯

问题描述

57. 爬楼梯(第八期模拟笔试)

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 

每次你可以爬至多m (1 <= m < n)个台阶。你有多少种不同的方法可以爬到楼顶呢? 

注意:给定 n 是一个正整数。

输入描述

输入共一行,包含两个正整数,分别表示n, m

输出描述

输出一个整数,表示爬到楼顶的方法数。

输入示例

3 2

输出示例

3

提示信息

数据范围:
1 <= m < n <= 32;

当 m = 2,n = 3 时,n = 3 这表示一共有三个台阶,m = 2 代表你每次可以爬一个台阶或者两个台阶。

此时你有三种方法可以爬到楼顶。

  1. 1 阶 + 1 阶 + 1 阶段
  2. 1 阶 + 2 阶
  3. 2 阶 + 1 阶

解题步骤

昨天的题目我们已经用二维数组实现了完全背包在排列问题和组合问题上的应用

那么今天我们用一维数组来简化一下方法,使代码更短,思路更清晰

首先审题!(不然就会跟我一样一直AC不了最后发现是n,m搞反了)

要先输入两个整数n,m

一定要看清楚n是总台阶数,m是最大步数

也就是说我们每次可以在1~m中选取,最后总和为n

用完全背包套一下定义就是

现在背包最大容量为n,我们有1~m号物品,价值,重量就是对应索引

所以这一题不需要额外的数组来存储物品价值,重量,一切和 i 表示的一致

动规五部曲

1.确定dp数组下标及含义

i 表示可以从1~i 步中选择

j表示台阶数

dp[i][j]表示每次走1~i阶台阶,到达j的方法有dp[i][j]种

以上是二维数组的定义,那么我们只要去掉i这个维度,就可以变成一维

因为每次加入一种步伐选择,我们的方案数都是在原来的基础上增加的

所以可以使用dp[ j ]来代表台阶为 j 时可选方案有dp[ j ]种

2.初始化

一维dp数组的初始化就很简单了,我们只要让dp[0]=1即可

表示0阶台阶有一种方法,就是不走

3.遍历顺序

从示例来看,当 m = 2,n = 3 时,有三种方法可以爬到楼顶

  1. 1 阶 + 1 阶 + 1 阶段
  2. 1 阶 + 2 阶
  3. 2 阶 + 1 阶

也就是说[1,2],[2,1]是不同组合,我们强调顺序

所以这题属于排列问题

需要先遍历背包容量(也就是台阶数),再遍历物品种类(也就是步伐)

 for(int j=1;j<=n;j++){//在初始化后一个状态开始生成

        for(int i=1;i<=m;i++){//步伐数属于[1,m]闭区间别忘记取等

 4.递推公式

当加入步伐数i时,依旧有两种选择,使用或者不使用

不使用那就是不改变当前状态对一维数组也就不需要更新

使用的话背包容量就要空出相应部分,前提是背包容量足够

if( j >= i ){

        dp[ j ]+=dp[ j-i ];

}

 5.发现错误即时打印dp检查一下!

最后只需要输出dp[n]即可,完整代码如下!

code

#include<bits/stdc++.h>
using namespace std;
int main(){int n,m;cin>>n>>m;vector<int> dp(n+1,0);dp[0]=1;for(int j=1;j<=n;j++){for(int i=1;i<=m;i++){if(j>=i)dp[j]+=dp[j-i];}}cout<<dp[n];return 0;
}

题目二:零钱兑换

问题描述

322. 零钱兑换 - 力扣(LeetCode)

给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。

计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1 。

你可以认为每种硬币的数量是无限的。

示例 1:

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

示例 2:

输入:coins = [2], amount = 3
输出:-1

示例 3:

输入:coins = [1], amount = 0
输出:0

提示:

  • 1 <= coins.length <= 12
  • 1 <= coins[i] <= 231 - 1
  • 0 <= amount <= 104

解题步骤

我们已经做过零钱兑换②

那么这个初代有什么不一样呢?

读题可以发现,这里求的是最少的硬币个数

之前的题目里我们有求背包最大价值,方案数等等

但这个求方案里的元素个数,并且是最小值,还是第一次见

所以递推公式我们需要重新考虑一下,其它小细节也不能放过

例行公事!(这里使用一维数组喽!)

1.确认dp数组下标及含义

dp[j]表示背包容量(硬币总额)为j时,选取物品(硬币)的最少个数,

vector<int >dp(amount+1);

2.初始化

 一维数组,特殊考虑dp[0]

dp[0]表示总和为0时,放硬币的个数,那必然为0

其它值我们应该初始化为不影响寻找最小值的

所以可以在定义时顺手初始化为INT_MAX

vector<int >dp(amount+1,INT_MAX);

dp[0]=0

3.遍历顺序

 由于这一题求的是元素个数,那么它是组合问题也好,排序问题也罢

都不会影响结果

所以先遍历背包再遍历物品,或者先遍历物品再遍历背包都可以

for(int i=0;i<n;i++){

        for(j=0;j<=amount;j++){ // j 的初始值待商榷

 4.递推公式

可以模拟只放第一种硬币来思考一下,

假如第一种硬币面额为2,需要硬币总额为10

那么:

dp[1]=INT_MAX(由于单个面额过大所以放不了,对当前值不做处理,依旧是初始化的INT_MAX),

dp[2]=1

dp[3]=INT_MAX

dp[4]=2

...

假如可以选择面额为2,5的两种硬币,总额依旧为10

那么

dp[1]=INT_MAX(塞不进去保留前面的状态)

dp[2]=1(不能塞5,保留)

dp[3]=INT_MAX(同上)

dp[4]=2(同上)

dp[5]=1=dp[0]+1(放入5需要清空前面的,所以变为dp[0],但我们会假如一枚硬币5,所以+1)

dp[6]=3

....

所以不放/放不进来情况下,dp[j]保持不变

腾出位置放入,dp[j]=dp[j-coins[i]]+1

或许看到这个式子会有疑问,

用j减去coins[i]这个i是当前值(假如当前j=6,coins[i]=4),那怎么不算我减少了2个硬币2呢?

确实,我们从6中腾出4个容量,是取出了2个硬币,加入4又增加了1,最后应该是2个

而dp[6]直接按照公式就是=dp[2]+1=1+1=2

就是当前取出4,被保留的是2状态,这是符合我们的放取逻辑的

最终递推公式为

dp[j]=min(dp[j],dp[j-coins[i]]+1);

填个坑!

此外需要注意的是出现下标为j-coins[i],那么不能数组越界,

所以j的初始值应该设置为j=coins[i]

最后应该返回dp[amount]

但同时题目要求:如果没有任何一种硬币组合能组成总金额,返回 -1 。

那怎么样算是没有组合呢?

当然就是还是初始值,没有发生改变的情况

if(dp[amount]==INT_MAX) return -1;

完整代码如下!

code

class Solution {
public:int coinChange(vector<int>& coins, int amount) {int n=coins.size();vector<int> dp(amount+1,INT_MAX);dp[0]=0;for(int i=0;i<n;i++){for(int j=coins[i];j<=amount;j++){if (dp[j - coins[i]] != INT_MAX) { // 如果dp[j - coins[i]]是初始值则跳过dp[j] = min(dp[j - coins[i]] + 1, dp[j]);}}}if(dp[amount]==INT_MAX) return -1;return dp[amount];}
};

相关文章:

【蓝桥杯速成】| 17.完全背包(一维easy版)

题目一&#xff1a;爬楼梯 问题描述 57. 爬楼梯&#xff08;第八期模拟笔试&#xff09; 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬至多m (1 < m < n)个台阶。你有多少种不同的方法可以爬到楼顶呢&#xff1f; 注意&#xff1a;给定 n 是一个正整…...

移动端六大语言速记:第4部分 - 数据结构

移动端六大语言速记&#xff1a;第4部分 - 数据结构 本文对比Java、Kotlin、Flutter(Dart)、Python、ArkTS和Swift这六种移动端开发语言的数据结构特性&#xff0c;帮助开发者快速掌握各语言的语法差异。 4. 数据结构 4.1 数组与列表 各语言数组与列表的语法对比&#xff1…...

开源鸿蒙分布式软总线技术研究报告

引言 在现代计算环境中&#xff0c;分布式系统的重要性日益凸显&#xff0c;尤其是在物联网&#xff08;IoT&#xff09;和无处不在的连接的背景下。各种智能设备数量的爆炸式增长以及用户对跨设备无缝体验的需求&#xff0c;推动了分布式操作系统的发展。开源鸿蒙正是在这样的…...

Geotools结合SLD实现矢量中文标注下的乱码和可用字体解析

目录 前言 一、需求溯源 1、原始的SLD渲染 2、最初的效果 二、问题修复 1、还是字符编码 2、如何选择可用的字体 3、如何查看支持的字体库 三、总结 前言 随着地理信息系统&#xff08;GIS&#xff09;技术的不断发展&#xff0c;矢量数据的可视化和标注成为了地理信息展…...

linux 服务器创建服务器启动后服务自启动

1、在/etc/systemd/system/下touch一个文件&#xff1a; touch /etc/systemd/system/your_application.service 2、在文件中写入&#xff1a; [Unit] Descriptionmodules-system Aftersyslog.target[Service] Typeforking Userroot Grouproot ExecStart/bin/bash /usr/loca…...

基于Python与CATIA V5的斐波那契螺旋线自动化建模技术解析

引言 斐波那契螺旋线&#xff08;Fibonacci Spiral&#xff09;作为自然界广泛存在的黄金比例曲线&#xff0c;在工业设计、产品造型、机械工程等领域具有重要应用价值。本文将以Python控制CATIA V5进行参数化建模为例&#xff0c;深入解析三维CAD环境中复杂数学曲线的自动化生…...

动态规划(11.按摩师)

题目链接&#xff1a;面试题 17.16. 按摩师 - 力扣&#xff08;LeetCode&#xff09; 解法&#xff1a; 状态表示&#xff1a; 对于简单的线性 dp &#xff0c;我们可以⽤「经验 题⽬要求」来定义状态表⽰&#xff1a; 以某个位置为结尾&#xff0c;巴拉巴拉&#xff1b;…...

CentOS下安装Docker,Docker下安装JDK\MYSQL\REDIS\NGINX

先用VM安装好Centos8.5&#xff0c;可以选择安装迷你版&#xff0c;我安装的是UI版。 然后用MobaXterm_Portable_v23.0_cn连上去&#xff0c;互访成功就可以往下操作。 1. 修改文件&#xff1a;就是要把之前的mirror替换成现在的vault cd /etc/yum.repos.d/sed -i s/mirrorl…...

demo.launch(inbrowser=True, share=True)无法生成共享网址

Gradio 的共享功能无法正常工作&#xff0c;原因是缺少一个名为 frpc_windows_amd64_v0.3 用到代码 app.demo.launch(show_errorTrue, inbrowserTrue, shareTrue) show_errorTrue&#xff1a;这个参数的作用是当应用在启动过程中出现错误时&#xff0c;会显示错误信息。这对于调…...

翻译: 人工智能如何让世界变得更美好二

Basic assumptions and framework 基本假设和框架 To make this whole essay more precise and grounded, it’s helpful to specify clearly what we mean by powerful AI (i.e. the threshold at which the 5-10 year clock starts counting), as well as laying out a fram…...

【vue】editor富文本输入全英文,谷歌浏览器:元素不会自动换行bug

【vue】editor富文本输入全英文&#xff0c;谷歌浏览器&#xff1a;元素不会自动换行bug 解决方案&#xff1a;给元素一个宽度 100% .editor {width: 100%; }...

XML标签格式转换为YOLO TXT格式

针对的是多边形&#xff08;<polygon>&#xff09;来描述对象的边界&#xff0c;而不是传统的矩形框&#xff08;<bndbox>&#xff09; import xml.etree.ElementTree as ET import os from pathlib import Path# 解析VOC格式的XML文件&#xff0c;提取目标框的标…...

# OpenCV实现人脸与微笑检测:从图像到视频的实战应用

OpenCV实现人脸与微笑检测&#xff1a;从图像到视频的实战应用 在计算机视觉领域&#xff0c;人脸检测和微笑检测是两个非常有趣且实用的任务。它们广泛应用于智能监控、社交媒体分析、人机交互等多个场景。本文将通过两个代码示例&#xff0c;详细介绍如何使用OpenCV实现人脸…...

【ubuntu24.04】挂载windows的共享文件夹

挂载windows的共享文件夹 ubutnu直接挂载windows共享文件夹&#xff0c;这样就能直接访问到windows里下载的文件了。 在 Ubuntu 中挂载 Windows 共享文件夹通常使用 CIFS 协议&#xff0c;下面给出一个常用的方法&#xff1a; 1. 安装 cifs-utils 首先&#xff0c;确保系统…...

基于Python的Django框架的个人博客管理系统

标题:基于Python的Django框架的个人博客管理系统 内容:1.摘要 本文围绕基于Python的Django框架构建个人博客管理系统展开。背景方面&#xff0c;随着互联网发展&#xff0c;个人博客成为信息分享与交流重要平台&#xff0c;传统博客管理系统在功能与灵活性上存在不足。目的是开…...

Kubernetes可视化面板——KubePi(Kubernetes Visualization Panel - kubepi)

Kubernetes可视化管理面板——KubePi 在云计算和容器化的大潮下&#xff0c;Kubernetes 已成为管理容器集群的事实标准。然而&#xff0c;面对复杂的集群管理和运维工作&#xff0c;一个直观、易用的可视化工具显得至关重要。KubePi 正是为此而生——一款专为简化 Kubernetes …...

【区块链安全 | 第二十三篇】单位和全局可用变量(一)

文章目录 单位和全局可用变量&#xff08;Units and Globally Available Variables&#xff09;以太单位&#xff08;Ether Units&#xff09;时间单位&#xff08;Time Units&#xff09;保留关键字 单位和全局可用变量&#xff08;Units and Globally Available Variables&am…...

6内存泄露问题的讨论

1.关注 内存泄露 是要融入到 DNA 中的事情 内存泄露是一个非常害怕, 非常严重的事情!! (不仅仅是内存泄露,包括文件描述符泄露等同类问题,都是非常严重的) 这种问题,不容易第一时间发现 2.实际场景中&#xff1a;特别是选择性关闭文件描述符 &#xff08;也是记得要关闭文件描…...

权重参数矩阵

目录 1. 权重参数矩阵的定义与作用 2. 权重矩阵的初始化与训练 3. 权重矩阵的解读与分析 (1) 可视化权重分布 (2) 统计指标分析 4. 权重矩阵的常见问题与优化 (1) 过拟合与欠拟合 (2) 梯度问题 (3) 权重对称性问题 5. 实际应用示例 案例1&#xff1a;全连接网络中的…...

Ludic:用Python构建HTML,告别JavaScript的繁琐开发

在现代Web开发中&#xff0c;构建动态网页和应用程序往往需要同时处理前端JavaScript和后端逻辑&#xff0c;这种复杂性让开发者倍感压力。Ludic框架的诞生&#xff0c;为开发者提供了一种全新的解决方案——通过Python的类型系统和组件化设计&#xff0c;让HTML生成变得简洁高…...

【现代深度学习技术】现代卷积神经网络06:残差网络(ResNet)

【作者主页】Francek Chen 【专栏介绍】 ⌈ ⌈ ⌈PyTorch深度学习 ⌋ ⌋ ⌋ 深度学习 (DL, Deep Learning) 特指基于深层神经网络模型和方法的机器学习。它是在统计机器学习、人工神经网络等算法模型基础上&#xff0c;结合当代大数据和大算力的发展而发展出来的。深度学习最重…...

SpringBoot分布式项目订单管理实战:Mybatis最佳实践全解

一、架构设计与技术选型 典型分布式订单系统架构&#xff1a; [网关层] → [订单服务] ←→ [分布式缓存]↑ ↓ [用户服务] [支付服务]↓ ↓ [MySQL集群] ← [分库分表中间件]技术栈组合&#xff1a; Spring Boot 3.xMybatis-Plus 3.5.xShardingSpher…...

《异常检测——从经典算法到深度学习》30. 在线服务系统中重复故障的可操作和可解释的故障定位

《异常检测——从经典算法到深度学习》 0 概论1 基于隔离森林的异常检测算法 2 基于LOF的异常检测算法3 基于One-Class SVM的异常检测算法4 基于高斯概率密度异常检测算法5 Opprentice——异常检测经典算法最终篇6 基于重构概率的 VAE 异常检测7 基于条件VAE异常检测8 Donut: …...

题解:蓝桥杯 2023 省 B 接龙数列 - dp + 哈希map

题解&#xff1a;蓝桥杯 2023 省 B 接龙数列 题目传送门 P9242 [蓝桥杯 2023 省 B] 接龙数列 一、题目描述 给定一个长度为N的整数数列&#xff0c;我们需要计算最少删除多少个数&#xff0c;可以使剩下的序列成为接龙序列。接龙序列的定义是&#xff1a;对于序列中相邻的两…...

RAG 优化:高效解析并接入图文、表格密集型文档

写在前面 检索增强生成 (Retrieval-Augmented Generation, RAG) 已成为构建智能问答、文档摘要、内容创作等应用的利器。然而,标准的 RAG 流程往往假设输入是纯文本。当我们面对现实世界中更常见的文档——那些充斥着大量图片、图表和表格的报告、手册、论文或网页时,传统的…...

nut-ui下拉选的实现方式:nut-menu

nut-ui下拉选的实现方式&#xff1a;nut-menu 官方文档&#xff1a;https://nutui.jd.com/h5/vue/4x/#/zh-CN/component/menu 案例截图&#xff1a; nut-tab选项卡组件实现&#xff1a; 官方组件地址&#xff1a;https://nutui.jd.com/h5/vue/4x/#/zh-CN/component/tabs nut…...

HTML中数字和字母不换行显示

HTML中数字和字母不换行显示的默认行为及如何通过CSS的word-wrap和word-break属性进行调整。 在HTML中标签中的数字和字母默认是不换行的&#xff0c;如果要将他们换行&#xff0c;在CSS中添加”word-wrap: break-word;” 即可解决 语法&#xff1a;word-wrap: normal|break-w…...

鸿蒙NEXT小游戏开发:扫雷

1. 引言 本文将介绍如何使用鸿蒙NEXT框架开发一个简单的扫雷游戏。通过本案例&#xff0c;您将学习到如何利用鸿蒙NEXT的组件化特性、状态管理以及用户交互设计来构建一个完整的游戏应用。 2. 环境准备 电脑系统&#xff1a;windows 10 工程版本&#xff1a;API 12 真机&…...

【doris】Apache Doris简介

目录 1. 概述2. 技术特点2.1 高性能查询2.2 实时数据导入2.3 易于使用2.4 高可扩展性2.5 数据模型2.6 容错性 3. 适用场景4. 部署与架构4.1 部署方式4.2 架构特点 5. 优势 1. 概述 1.Apache Doris&#xff08;原名Palo&#xff09;最早诞生于百度广告报表业务&#xff0c;2017…...

LangChain4j 入门(二)

LangChain 整合 SpringBoot 下述代码均使用 阿里云百炼平台 提供的模型。 创建项目&#xff0c;引入依赖 通过 IDEA 创建 SpringBoot 项目&#xff0c;并引入 Spring Web 依赖&#xff0c;SpringBoot 推荐使用 3.x 版本。 引入 LangChain4j 和 WebFlux 依赖 <!--阿里云 D…...