careercup-高等难度 18.7

18.7 给定一组单词,编写一个程序,找出其中的最长单词,且该单词由这组单词中的其他单词组合而成。

解法:

原题

给定字符串,以及一个字典,判断字符串是否能够拆分为字段中的单词。例如,字段为{hello,world},字符串为hellohelloworld,则可以拆分为hello,hello,world,都是字典中的单词。

分析

这个题目唤作“分词问题”,略显宽泛。只是想提及这个问题,这是在自然语言处理,搜索引擎等等领域中,非常基础的一个问题,解决的方法也比较多,相对比较成熟,不过这仍旧是一个值得进一步探索的问题。那我们先从这个简单的题目入手,看看如何处理题目中这个问题。 最直接的思路就是递归,很简单。我们考虑每一个前缀,是否在字典中?如果在,则递归处理剩下的字串,如果不在;则考虑其他前缀。示例代码如下:

递归的方法实现:

但是这样会有很多重复的查找:

这个题目的处理,上期的题目是很相似的。在递归子问题中,找重复的子问题。也非常明显,如下图(图片来自GeeksforGeeks)所示:

如果使用动态规划的方法:

    bool wordBreak(string s, unordered_set<string> &dict) {
        if(dict.empty()||s.empty())
            return false;
        unordered_map<string,bool> mp;
        auto iter=dict.begin();
        while(iter!=dict.end())
        {
            mp[*iter]=true;
            iter++;
        }
        return canBuildWord(s,mp);
    }
    bool canBuildWord(string s,unordered_map<string,bool> &mp)
    {
        if(mp.find(s)!=mp.end())
            return mp[s];
        for(int i=1;i<=s.length();i++)
        {
            string left=s.substr(0,i);
            string right=s.substr(i);
            if(mp.find(left)!=mp.end()&&mp[left]==true&&canBuildWord(right,mp))
                return true;
        }
        mp[s]=false;
        return false;
    }

其中使用动态规划的方法缓存了多次调用之间的结果。如果该字符串在map中没有找到,那么将该字符串插入到map中,并将其值置为false,如果下次还是查找该字符串且该字符串在map中,并且值为false,则可以直接返回其在map中存放的值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用中提到了解决npm版本与node版本不匹配的问题的方法。你可以使用命令`node -v`查看当前的node版本,***根据引用中的提示,你可以执行命令`npm install -g npm@7.5.6`来安装npm的7.5.6版本。 另外,引用中提到了修改项目中的package.json文件来更新node-sass和sass-loader的版本号。你可以按照引用中给出的示例将"node-sass"的版本修改为"^8.0.0",将"sass-loader"的版本修改为"^10.4.1"。 最后,引用中提到了一段代码,用于设置环境变量。如果你需要在编辑模式下执行这段代码,按下"e"键进入编辑模式,然后将代码粘贴进去。记得将代码中的"node保存路径"替换为你的实际node保存路径。 综上所述,根据你的问题描述,你可以按照以上步骤进行node 18.7的安装。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [node 版本与npm版本不相匹配](https://blog.csdn.net/yang_guang3/article/details/114444488)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [解决node升级到18版本node-sass安装问题](https://blog.csdn.net/playboyanta123/article/details/129047647)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [linux node下载以及环境配置](https://blog.csdn.net/aruis_1997/article/details/118513490)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值