动态规划 Leetcode 139 单词拆分

单词拆分

Leetcode 139

学习记录自代码随想录

要点在注释中详细说明,注意迭代公式中是dp[i]不是dp[j-i]

c 复制代码
#include <stdio.h>
#include <string.h>
#include <stdbool.h>
#include <stdlib.h>


bool wordBreak(char* s, char** wordDict, int wordDictSize) {

    // 1.dp[j]代表背包容量为字符串s的长度j时是否可以利用字典中单词拼接为字符串s,dp[j]为true和false,
    bool dp[strlen(s)+1];
    memset(dp, false, sizeof(dp));
    // 2.递推公式,if(j到i之间的字符串在wordDict中 && dp[j-i]为true) 则dp[j]为true
    // 3.dp数组初始化,dp[0] = true;
    dp[0] = true;
    // 4.遍历顺序,本题中字符串组合顺序不能改变所以实际上是排列问题,所以先遍历背包,再遍历物品
    for(int j = 0; j < strlen(s)+1; j++){
        for(int i = 0; i < j; i++){
            int length = j - i;
            char sub_str[length+1];
            strncpy(sub_str, s+i, length);
            sub_str[length] = '\0';
            for(int k = 0; k < wordDictSize; k++){
                if((strcmp(wordDict[k], sub_str) == 0) && dp[i]){
                    dp[j] = true;
                }
            }
            
        }
    }
    // 5.举例推导dp数组
    return dp[strlen(s)];
}

int main(){
    int n;
    scanf("%d", &n);
    while(n){
        char s[301];
        scanf("%s", &s);
        int wordDictSize;
        scanf("%d", &wordDictSize);
        char** wordDict = (char**)malloc((wordDictSize) * sizeof(char*));
        for(int i = 0; i < wordDictSize; i++){
            wordDict[i] = (char*)malloc(21 * sizeof(char));
            scanf("%s", wordDict[i]);
        }
        bool result = wordBreak(s, wordDict, wordDictSize);
        printf("%d", result);
        for(int i = 0; i < wordDictSize; i++){
            free(wordDict[i]);
        }
        free(wordDict);
    }
    return 0;
}
相关推荐
散峰而望23 分钟前
C++数组(三)(算法竞赛)
开发语言·c++·算法·github
q***952227 分钟前
SpringMVC 请求参数接收
前端·javascript·算法
初级炼丹师(爱说实话版)42 分钟前
多进程与多线程的优缺点及适用场景总结
算法
hetao17338371 小时前
2025-11-25~26 hetao1733837的刷题记录
c++·算法
历程里程碑1 小时前
各种排序法大全
c语言·数据结构·笔记·算法·排序算法
少许极端1 小时前
算法奇妙屋(十四)-简单多状态dp问题
算法·动态规划·图解算法·简单多状态dp·打家劫舍问题·买卖股票问题全解
2301_823438022 小时前
解析论文《复杂海上救援环境中无人机群的双阶段协作路径规划与任务分配》
人工智能·算法·无人机
embrace992 小时前
【C语言学习】结构体详解
android·c语言·开发语言·数据结构·学习·算法·青少年编程
Ayanami_Reii3 小时前
基础数学算法-开关问题
数学·算法·高斯消元
稚辉君.MCA_P8_Java3 小时前
通义 Go 语言实现的插入排序(Insertion Sort)
数据结构·后端·算法·架构·golang