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