代码随想录算法训练营第四十六天|139.单词拆分,多重背包,背包问题总结

本文主要是介绍代码随想录算法训练营第四十六天|139.单词拆分,多重背包,背包问题总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 139.单词拆分
    • 思路
    • 代码
  • 多重背包
    • 思路
    • 代码
  • 背包问题总结

139.单词拆分

题目链接:704. 二分查找

文档讲解:代码随想录

视频讲解:动态规划之完全背包,你的背包如何装满?| LeetCode:139.单词拆分

思路

dp数组dp[i]表示长度为i的字符串是否可以拆分为一个或多个再字典中出现的单词。

递推公式:如果dp[j]为true,且[j, i]区间的字串出现在字典中,则dp[i]为true。

如:对于dp[i],遍历j=0~i,如果字串[j, i]出现在字典中,且dp[j]为true,则dp[i]为true。

代码

class Solution {
public:bool wordBreak(string s, vector<string> &wordDict) {unordered_set<string> wordSet(wordDict.begin(), wordDict.end());vector<bool> dp(s.size() + 1, false);dp[0] = true;for (int i = 0; i <= s.size(); i++) {for (int j = 0; j <= i; j++) {string word = s.substr(j, i - j);if (wordSet.find(word) != wordSet.end() && dp[j])dp[i] = true;}}return dp[s.size()];}
};

多重背包

题目链接:56. 携带矿石资源(第八期模拟笔试)

文档讲解:代码随想录

思路

将多重背包中的所有物品展开,则转换为01背包问题。

代码

#include <iostream>
#include <vector>
#include <string>
#include <unordered_set>using namespace std;int main() {int C, N;cin >> C >> N;vector<int> weights(N, 0);vector<int> values(N, 0);vector<int> nums(N, 0);for (int i = 0; i < N; i++)cin >> weights[i];for (int i = 0; i < N; i++)cin >> values[i];for (int i = 0; i < N; i++)cin >> nums[i];int num_count = 0;for (auto i : nums)num_count += i;vector<int> stones_weights(num_count, 0);vector<int> stones_values(num_count, 0);int index = 0;for (int i = 0; i < N; i++) {for (int j = 0; j < nums[i]; j++) {stones_weights[index] = weights[i];stones_values[index] = values[i];index++;}}vector<int> dp(C + 1, 0);for (int i = 0; i < stones_weights.size(); i++) {for (int j = C; j >= stones_weights[i]; j--) {dp[j] = max(dp[j], dp[j - stones_weights[i]] + stones_values[i]);}}cout << dp[C] << endl;
}

背包问题总结

文档讲解:代码随想录

按背包类型分类:01背包、完全背包、多重背包等。

  • 01背包:遍历背包时从后向前遍历
  • 完全背包:遍历背包时从前向后遍历
  • 多重背包:将物品展开转换为01背包问题

按所求问题分类:能否装满背包,背包最多装多少,装满背包有多少种方法,背包装满最大价值,装满背包所需最小物品数。

  • 能否装满背包:dp[j] = max(dp[j], dp[j - nums[i]] + nums[i]),即01背包问题中价值和重量相同,装完背包后,最大价值与背包容量相同则可以装满背包。
  • 背包最多装多少:dp[j] = max(dp[j], dp[j - nums[i]] + nums[i]),即01背包问题中价值和重量相同。
  • 装满背包有多少种方法:dp[j] += dp[j - nums[i]]。
  • 背包装满最大价值:dp[j] = max(dp[j], dp[j - weight[i]] + value[i])。
  • 装满背包所需最小物品数:dp[j] = min(dp[j], dp[j - nums[i]] + 1)。

遍历顺序

  • 求组合数:外层循环遍历物品,内层循环遍历背包。
  • 求排列数:外层循环遍历背包,内层循环遍历物品。

这篇关于代码随想录算法训练营第四十六天|139.单词拆分,多重背包,背包问题总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/983268

相关文章

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

关于MongoDB图片URL存储异常问题以及解决

《关于MongoDB图片URL存储异常问题以及解决》:本文主要介绍关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录MongoDB图片URL存储异常问题项目场景问题描述原因分析解决方案预防措施js总结MongoDB图

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

usb接口驱动异常问题常用解决方案

《usb接口驱动异常问题常用解决方案》当遇到USB接口驱动异常时,可以通过多种方法来解决,其中主要就包括重装USB控制器、禁用USB选择性暂停设置、更新或安装新的主板驱动等... usb接口驱动异常怎么办,USB接口驱动异常是常见问题,通常由驱动损坏、系统更新冲突、硬件故障或电源管理设置导致。以下是常用解决

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1

SpringBoot内嵌Tomcat临时目录问题及解决

《SpringBoot内嵌Tomcat临时目录问题及解决》:本文主要介绍SpringBoot内嵌Tomcat临时目录问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录SprinjavascriptgBoot内嵌Tomcat临时目录问题1.背景2.方案3.代码中配置t