动态规划 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;
}
相关推荐
YuTaoShao12 分钟前
【LeetCode 热题 100】994. 腐烂的橘子——BFS
java·linux·算法·leetcode·宽度优先
Wendy14418 小时前
【线性回归(最小二乘法MSE)】——机器学习
算法·机器学习·线性回归
拾光拾趣录8 小时前
括号生成算法
前端·算法
渣呵9 小时前
求不重叠区间总和最大值
算法
拾光拾趣录9 小时前
链表合并:双指针与递归
前端·javascript·算法
好易学·数据结构9 小时前
可视化图解算法56:岛屿数量
数据结构·算法·leetcode·力扣·回溯·牛客网
香蕉可乐荷包蛋10 小时前
AI算法之图像识别与分类
人工智能·学习·算法
chuxinweihui10 小时前
stack,queue,priority_queue的模拟实现及常用接口
算法
tomato0910 小时前
河南萌新联赛2025第(一)场:河南工业大学(补题)
c++·算法
墨染点香11 小时前
LeetCode Hot100【5. 最长回文子串】
算法·leetcode·职场和发展