Day 42算法记录| 动态规划 08

这里写目录标题

139. 单词拆分

单词就是物品,字符串s就是背包

1.dp[0]背包啥也不要用装,true。

  1. for循环,顺序很重要,所以先背包再物品
    如果求组合数就是外层for循环遍历物品,内层for遍历背包
    如果求排列数就是外层for遍历背包,内层for循环遍历物品

3.递归:

要么装包或者不装

添加链接描述

java 复制代码
class Solution {
    public boolean wordBreak(String s, List<String> wordDict) {
        int len = s.length();
     boolean[] dp = new boolean[len+1];
     dp[0] = true;
     for(int i=1;i<=len;i++){ //背包
        for(String word : wordDict){
            int n = word.length();
            if(i>=n&&word.equals(s.substring(i-n,i))){
                dp[i] =  dp[i] ||dp[i-n];
            }
        }
     }
     return dp[len];
    }
}

多重背包问题

背包问题总结

把这五部都搞透了,算是对动规来理解深入了。

确定dp数组(dp table)以及下标的含义

确定递推公式

dp数组如何初始化

确定遍历顺序

举例推导dp数组


2.遍历顺序
一维:第二层的背包是从大到小
注意for循环分别表示的含义

相关推荐
l1t1 分钟前
在duckdb 递归CTE中实现深度优先搜索DFS
sql·算法·深度优先·duckdb·cte
陈陈爱java18 分钟前
RRT建模
算法
智算菩萨26 分钟前
摩擦电纳米发电机近期进展的理论脉络梳理:从接触起电到统一建模与能量转换
linux·人工智能·算法
xiaolang_8616_wjl27 分钟前
c++超级细致的基本框架
开发语言·数据结构·c++·算法
艾醒1 小时前
大模型原理剖析——拆解预训练、微调、奖励建模与强化学习四阶段(以ChatGPT构建流程为例)
算法
冷崖1 小时前
排序--基数排序
c++·算法
F_D_Z1 小时前
哈希表解Two Sum问题
python·算法·leetcode·哈希表
Aaron15881 小时前
基于RFSOC+VU13P+GPU架构在雷达电子战的技术
人工智能·算法·fpga开发·架构·硬件工程·信号处理·基带工程
LYFlied1 小时前
【每日算法】LeetCode124. 二叉树中的最大路径和
数据结构·算法·leetcode·面试·职场和发展
talenteddriver2 小时前
java: Java8以后hashmap扩容后根据高位确定元素新位置
java·算法·哈希算法