Java 题解 | #训练聪明的牛#

训练聪明的牛

https://www.nowcoder.com/practice/971090dbcf5043e295b4ea7f6ec85311

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param s string字符串
     * @param wordDict string字符串一维数组
     * @return bool布尔型
     */
    public boolean wordBreak (String s, String[] wordDict) {
        // write code here
        HashSet<String> set = new HashSet<>();
        for (String word : wordDict) {
            StringBuilder sb = new StringBuilder(word);
            sb.reverse();
            set.add(sb.toString());
        }

        int n = s.length();
        boolean[] dp = new boolean[n + 1];
        dp[0] = true;
        for (int i = 1; i <= n; i++) {
            StringBuilder cur = new StringBuilder();
            for (int j = i - 1; j >= 0; j--) {
                cur.append(s.charAt(j));
                if (set.contains(cur.toString())) {
                    dp[i] = dp[i] || dp[j];
                }
                if (dp[i] || cur.length() > 25) {
                    break;
                }
            }
        }
        return dp[n];
    }
}

编程语言是Java。

该题考察的知识点是动态规划和字符串处理。

代码简短的文字解释如下:

  1. wordDict中的单词逆序,并存储在HashSet集合set中。这样可以方便地检查一个字符串的逆序是否存在于wordDict中。
  2. 创建一个长度为n+1的布尔数组dp,其中dp[i]表示从字符串s的前i个字符能否被分割成由wordDict中的单词组成的句子。
  3. 初始化dp[0]true,表示空字符串可以被分割。
  4. 遍历字符串s,从第一个字符开始到最后一个字符:对于当前位置i,构建一个空的StringBuilder对象cur来记录从s的第i-1个字符开始往前的部分字符。从i-1往前遍历,将字符添加到cur中,并检查cur的逆序是否存在于set中。如果存在,则说明从s的第j个字符(j从i-1到0循环)到第i个字符可以被分割,此时将dp[i]标记为true。如果不存在,并且当前逆序字符串的长度超过25,说明无法继续匹配更长的字符串,跳出循环。
  5. 最后返回dp[n],即表示整个字符串s是否能够被分割成由wordDict中的单词组成的句子。
全部评论

相关推荐

10-13 22:56
门头沟学院 C++
rt,鼠鼠的浪潮网签明天过期,鼠鼠是山东人,好像自己也能接受。之前的面试大厂基本挂干净了,剩下小米二面后在泡,问了下面试官没有挂,但要泡。还有海信似乎也通过了,不过在深圳,鼠鼠也不是很想去。其它还有一些公司应该陆陆续续还有一些面试,现在有些纠结是直接签了还是再等再面呢?大佬们能不能给鼠鼠提一些意见,万分感谢!!!
牛客78696106...:浪潮可不是开摆,当初我还是开发的时候我组长跟我说他们组有段时间天天1,2点走,早上5点就来,全组肝出来心肌炎,浪潮挣钱省立花可不是说说,当然也看部门,但是浪潮普遍就那dio样,而且你算下时薪就知道不高,没事也是9点半走,不然算你旷工
投递小米集团等公司10个岗位
点赞 评论 收藏
分享
点赞 评论 收藏
分享
09-09 13:30
四川大学 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务