C语言Leetcode每日一题(2024-1-9)2707.字符串中的额外字符

文章介绍了如何使用动态规划的方法,结合哈希表(字典),解决给定字符串中使所有子串成为字典中成员所需的最小额外字符数量的问题。作者给出了`substr`和`map_find`函数,并详细描述了`minExtraChar`函数的实现过程。
摘要由CSDN通过智能技术生成

原题链接:. - 力扣(LeetCode)

采取动态规划的思路,dictionary直接作为哈希表来查找

思路为两类子问题:1.直接将末尾字符当作额外字符,转化为前n-1个字符的子问题

2.找到一个j,使得[j,n-1]处的字符为dictionary中的字符,则转化为前j-1个字符的子问题

dp[i]表示前i个字符中最小额外字符的数量

代码如下:

char *substr(char *str, int start, int len) {
    char *sub = (char*) malloc(len + 1);
    strncpy(sub, str + start, len);
    sub[len] = '\0';
    return sub;
}

int map_find(char**dictionary,int dictionarySize,char* s){
    for(int i=0;i<dictionarySize;i++){
        if(!strcmp(dictionary[i],s))
            return 1;
    }
    return 0;
}

int minExtraChar(char * s, char ** dictionary, int dictionarySize){
    int n=strlen(s);
    int dp[n+1];
    memset(dp,INT_MAX,n+1);
    dp[0]=0;
    for(int i=1;i<=n;i++){
        dp[i]=dp[i-1]+1;
        for(int j=i-1;j>=0;j--){
            if(map_find(dictionary,dictionarySize,substr(s,j,i-j))){
                dp[i]=fmin(dp[i],dp[j]);
            }
        }
    }
    return dp[n];
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值