[Leetcode] 动态规划类java题解

[Leetcode] 动态规划类java题解,第1张

139. 单词拆分

public class WordBreak {

    public boolean wordBreak(String s, List wordDict) {
        Set wordSet = new HashSet(wordDict);
        boolean[] dp = new boolean[s.length() + 1];  //Boolean会抛空指针
        dp[0] = true;
        for (int i = 1; i <= s.length(); i++) {
            for (int j = 0; j < i; j++) {
                if (dp[j] && wordSet.contains(s.substring(j, i))) {
                    dp[i] = true;
                    break;
                }
            }
        }
        return dp[s.length()];
    }
    
}

152. 乘积最大子数组

class Solution {
     public int maxProduct(int[] nums) {

        int  n = nums.length;
        int[] dp = new int[n];
        dp[0]=nums[0];
        int result  = nums[0], nmax = nums[0], nmin = nums[0];
        for(int i = 1;i

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/799508.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-06
下一篇 2022-05-06

发表评论

登录后才能评论

评论列表(0条)