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

原题链接:. - 力扣(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];
}

  • 15
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值