zoukankan      html  css  js  c++  java
  • Java实现 LeetCode 139 单词拆分

    139. 单词拆分

    给定一个非空字符串 s 和一个包含非空单词列表的字典 wordDict,判定 s 是否可以被空格拆分为一个或多个在字典中出现的单词。

    说明:

    拆分时可以重复使用字典中的单词。
    你可以假设字典中没有重复的单词。
    示例 1:

    输入: s = “leetcode”, wordDict = [“leet”, “code”]
    输出: true
    解释: 返回 true 因为 “leetcode” 可以被拆分成 “leet code”。
    示例 2:

    输入: s = “applepenapple”, wordDict = [“apple”, “pen”]
    输出: true
    解释: 返回 true 因为 “applepenapple” 可以被拆分成 “apple pen apple”。
    注意你可以重复使用字典中的单词。
    示例 3:

    输入: s = “catsandog”, wordDict = [“cats”, “dog”, “sand”, “and”, “cat”]
    输出: false

    class Solution {
      public boolean wordBreak(String s, List<String> wordDict) {
            Map hasCompute = new HashMap<Integer,Boolean>();
            return wordBreak(s,wordDict,0,hasCompute);
        }
        public boolean wordBreak(String s,List<String> wordDict,int index,Map hasCompute){
            //找到所有可能性
            boolean result = false;
            for(String word:wordDict){
               if(s.startsWith(word,index)){               
                   index+=word.length();
                   //先判断之前是否已经计算过
                   if(hasCompute.containsKey(index)) return false;//如果已经计算过,说明是失败的
                   if(index == s.length()) return true;//递归结束条件
                   if(wordBreak(s,wordDict,index,hasCompute)) return true;//如果找到了,直接返回
                   else{
                       //记录已经计算的字符串
                       if(!hasCompute.containsKey(index)){
                           hasCompute.put(index,false);
                       }
                       //把index还原
                       index-=word.length();  
                    } 
                }
            }
            return result;
        }
    }
    
  • 相关阅读:
    基于BGP/EVPN控制平面的VXLAN anycast-VTEP anycast-gateway基本配置
    NetworkManager配置VRF
    IBGP Segment Routing AIGP属性
    EBGP segment routing
    CentOS8创建网桥
    F5 HTTP response body rewrite
    OSPF Segment Routing和MPLS基本配置
    L2TP 和 IPsec over L2TP
    nmap
    LINUX DNS客户端 解析域名慢的问题。
  • 原文地址:https://www.cnblogs.com/a1439775520/p/12946768.html
Copyright © 2011-2022 走看看