日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

leetcode算法题解(Java版)-16-动态规划(单词包含问题)

發布時間:2024/8/23 java 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 leetcode算法题解(Java版)-16-动态规划(单词包含问题) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

摘要:?碰到二叉樹的問題,差不多就是深搜、廣搜,遞歸那方面想想了,當然如果要考慮一下空間、時間,還需要進行剪枝和壓縮處理。這題比較簡單:判斷兩個樹是否相等,可以遞歸的判斷子樹是否相等,最后找到邊界條件就是是否都為空,都不為空時節點里面的值是否相等。

一、遞歸

題目描述

Given two binary trees, write a function to check if they are equal or not.?
Two binary trees are considered equal if they are structurally identical and the nodes have the same value.

思路

  • 碰到二叉樹的問題,差不多就是深搜、廣搜,遞歸那方面想想了,當然如果要考慮一下空間、時間,還需要進行剪枝和壓縮處理。這題比較簡單:判斷兩個樹是否相等,可以遞歸的判斷子樹是否相等,最后找到邊界條件就是是否都為空,都不為空時節點里面的值是否相等。

代碼

/*** Definition for binary tree* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode(int x) { val = x; }* }*/ public class Solution {public boolean isSameTree(TreeNode p, TreeNode q) {if(p==null&&q==null){return true;}else if(p==null||q==null){return false;}else if(q.val!=p.val){return false;}else{return isSameTree(p.left,q.left)&&isSameTree(p.right,q.right);}} }

二、動態規劃

題目描述

Given a string s and a dictionary of words dict, determine if s can be segmented into a space-separated sequence of one or more dictionary words.?
For example, given
s ="leetcode",
dict =["leet", "code"].?
Return true because"leetcode"can be segmented as"leet code".

思路

  • dp的題目,寫了幾道了。核心無非就是確定dp數組和狀態轉移方程。這幾道題都有明顯的特點,那就是dp數組記錄的就是所求的答案,所以答案一般都是dp[s.length()]這種形式的。
  • 有了上面的總結,再來看著道題目。要求一串字母是否可以由所給的字典中的單詞拼出來,要求返回布爾型。那好,也同時提示我們了dp數組就是記錄它的子串是否能滿足要求,類型是布爾型:dp[i]表示的是s[0,i-1]這個子串能否滿足要求。
  • dp[i]=dp[j]&&s[j,i]是否在字典中(0<=j<=i-1)

代碼

import java.util.Set;public class Solution {public boolean wordBreak(String s, Set<String> dict) {if(s==null||s.length()==0||dict==null||dict.size()==0){return false;}boolean [] dp = new boolean [s.length()+2];dp[0] = true;for(int i=1;i<=s.length();i++){for(int j=i-1;j>=0;j--){//從尾部掃描單詞if(dp[j]==true&&dict.contains(s.substring(j,i))){dp[i]=true;break;}else{dp[i]=false;}}}return dp[s.length()];} }

三、深搜

題目描述

Given a string s and a dictionary of words dict, add spaces in s to construct a sentence where each word is a valid dictionary word.?
Return all such possible sentences.?
For example, given
s ="catsanddog",
dict =["cat", "cats", "and", "sand", "dog"].?
A solution is["cats and dog", "cat sand dog"].

思路

  • 題目是上一道題的加強版,為了考察動態規劃。感覺有點復雜,沒想出來怎么在上一道的基礎上改進。
  • 深搜可以解決問題!直接看代碼了

代碼

import java.util.ArrayList; import java.util.Set;public class Solution {public ArrayList<String> res = new ArrayList<>();public ArrayList<String> wordBreak(String s, Set<String> dict) {dfs(s,s.length(),dict,"");return res;}public void dfs(String s,int index,Set<String> dict,String temp){if(index==0){if(temp.length()>0){res.add(temp.substring(0,temp.length()-1));//如果寫成res.add(temp)則末尾會多一個空格,小細節}}for(int i=index-1;i>=0;i--){if(dict.contains(s.substring(i,index))){dfs(s,i,dict,s.substring(i,index)+" "+temp);}}} }

原文鏈接

本文為云棲社區原創內容,未經允許不得轉載。


總結

以上是生活随笔為你收集整理的leetcode算法题解(Java版)-16-动态规划(单词包含问题)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 成年女人免费视频 | 天天av天天 | 成人精品亚洲人成在线 | 亚洲国产精品激情在线观看 | 91精品国产综合久久福利 | 日本裸体xx少妇18在线 | h片免费网站 | 91爱啪啪 | 韩国日本欧美一区 | h网站在线观看 | 任你操精品视频 | 国产白浆在线 | 欧美a在线视频 | 一本色道无码道dvd在线观看 | 欲色av| 久久久免费网站 | 麻豆回家视频区一区二 | 久久久久99精品成人片毛片 | 粉嫩av一区二区三区天美传媒 | 极品白嫩丰满少妇无套 | 欧美 日韩 高清 | 国产视频中文字幕 | 色偷偷成人 | 国产一级一片免费播放放a 丁香六月色 | 国产女人18毛片水真多18 | 国产精品久久久久三级 | 亚洲理论中文字幕 | 日韩欧美在线观看 | 98色| 理论片大全免费理伦片 | 日本一区二区欧美 | 先锋av在线资源 | 国产免费资源 | 欧美日韩在线影院 | 国产精品偷拍 | 午夜性色福利影院 | 午夜看片在线观看 | 日韩a级片| 国产成人欧美 | 精品欧美一区二区久久久久 | 国产女优在线播放 | 大陆极品少妇内射aaaaaa | 色偷偷综合 | 国产黄色激情视频 | 国产精品111 | 中文天堂资源在线 | 亚洲一一在线 | 男女做激情爱呻吟口述全过程 | 久久99精品波多结衣一区 | 婷婷综合一区 | 一区二区三区不卡视频在线观看 | 老司机av福利 | 国产一级二级视频 | 国产91久久久 | 亚洲欧美一区二区激情 | 动漫女生光屁股 | 桃花色综合影院 | 欧美日韩一区二区三区四区五区六区 | 丰满人妻一区二区三区免费 | 日韩草逼视频 | 日韩网站在线 | 精品久久久无码中文字幕 | 日本在线视频一区二区三区 | 大波大乳videos巨大 | 免费日韩 | 国产综合久久 | 华丽的外出在线观看 | m3u8成人免费视频 | 肉丝肉足丝袜一区二区三区 | 中文字幕一区二区三区在线不卡 | 一区二区在线播放视频 | 免费看成人 | 亚洲电影影音先锋 | 国产12页 | 精品影视 | 不卡一区在线 | 伊人青青久 | 成人123区| 成人精品一区日本无码网 | 波多野在线播放 | 久久亚洲AV成人无码国产人妖 | 午夜黄色网址 | 97久久久久 | 亚洲成熟少妇视频在线观看 | 午夜影院入口 | 国产精品hd | 人与性动交zzzzbbbb | 久草五月| 欧美三级免费看 | 黄色一级一片 | 九九这里只有精品视频 | 91精品日韩| 免费成人福利视频 | 操模特 | 边啃奶头边躁狠狠躁 | 色网站免费看 | 狠久久 | av一级 | 丝袜美女啪啪 |