自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

每日算法:回文子串

開發(fā) 前端 算法
給定一個字符串,你的任務是計算這個字符串中有多少個回文子串。具有不同開始位置或結束位置的子串,即使是由相同的字符組成,也會被視作不同的子串。

[[434467]]

給定一個字符串,你的任務是計算這個字符串中有多少個回文子串。

具有不同開始位置或結束位置的子串,即使是由相同的字符組成,也會被視作不同的子串。

示例 1:

  1. 輸入:"abc" 
  2.  
  3. 輸出:3 
  4.  
  5. 解釋:三個回文子串: "a""b""c" 

示例 2:

  1. 輸入:"aaa" 
  2.  
  3. 輸出:6 
  4.  
  5. 解釋:6個回文子串: "a""a""a""aa""aa""aaa" 

提示:

  • 輸入的字符串長度不會超過 1000 。

解法一:暴力法

  1. let countSubstrings = function(s) { 
  2.   let count = 0 
  3.   for (let i = 0; i < s.length; i++) { 
  4.     for (let j = i; j < s.length; j++) { 
  5.       if (isPalindrome(s.substring(i, j + 1))) { 
  6.         count++ 
  7.       } 
  8.     } 
  9.   } 
  10.   return count 
  11.  
  12. let isPalindrome = function(s) { 
  13.   let i = 0, j = s.length - 1 
  14.   while (i < j) { 
  15.     if (s[i] != s[j]) return false 
  16.     i++ 
  17.     j-- 
  18.   } 
  19.   return true 

復雜度分析:

  • 時間復雜度:O(n3)
  • 空間復雜度:O(1)

解法二:動態(tài)規(guī)劃

一個字符串是回文串,它的首尾字符相同,且剩余子串也是一個回文串。其中,剩余子串是否為回文串,就是規(guī)模小一點的子問題,它的結果影響大問題的結果。

我們怎么去描述子問題呢?

顯然,一個子串由兩端的 i 、j 指針確定,就是描述子問題的變量,子串 s[i...j] ( dp[i][j] ) 是否是回文串,就是子問題。

我們用二維數(shù)組記錄計算過的子問題的結果,從base case出發(fā),像填表一樣遞推出每個子問題的解。

  1.     j 
  2.     a  a  b  a 
  3. i a ✅ 
  4.   a    ✅   
  5.   b       ✅ 
  6.   a          ✅ 

注意: i<=j ,只需用半張表,豎向掃描

所以:

  1. i === j:dp[i][j]=true 
  2. j - i == 1 && s[i] == s[j]:dp[i][j] = true 
  3. j - i > 1 && s[i] == s[j] && dp[i + 1][j - 1]:dp[i][j] = true 

即:

  1. s[i] == s[j] && (j - i <= 1 || dp[i + 1][j - 1]): dp[i][j]=true 

否則為 false

代碼實現(xiàn):

  1. let countSubstrings = function(s) { 
  2.   const len = s.length 
  3.   let count = 0 
  4.   const dp = new Array(len) 
  5.  
  6.   for (let i = 0; i < len; i++) { 
  7.     dp[i] = new Array(len).fill(false
  8.   } 
  9.   for (let j = 0; j < len; j++) { 
  10.     for (let i = 0; i <= j; i++) { 
  11.       if (s[i] == s[j] && (j - i <= 1 || dp[i + 1][j - 1])) { 
  12.         dp[i][j] = true 
  13.         count++ 
  14.       } else { 
  15.         dp[i][j] = false 
  16.       } 
  17.     } 
  18.   } 
  19.   return count 

代碼實現(xiàn)(優(yōu)化):

把上圖的表格豎向一列看作一維數(shù)組,還是豎向掃描,此時僅僅需要將 dp 定義為一維數(shù)組即可

  1. let countSubstrings = function(s) { 
  2.   const len = s.length 
  3.   let count = 0 
  4.   const dp = new Array(len) 
  5.  
  6.   for (let j = 0; j < len; j++) { 
  7.     for (let i = 0; i <= j; i++) { 
  8.       if (s[i] === s[j] && (j - i <= 1 || dp[i + 1])) { 
  9.         dp[i] = true 
  10.         count++ 
  11.       } else { 
  12.         dp[i] = false 
  13.       } 
  14.     } 
  15.   } 
  16.   return count

復雜度分析:

  • 時間復雜度:O(n2)
  • 空間復雜度:O(n)

 

leetcode:https://leetcode-cn.com/problems/palindromic-substrings/solution/leetcode647hui-wen-zi-chuan-by-user7746o/

 

責任編輯:武曉燕 來源: 三分鐘學前端
相關推薦

2021-09-03 09:41:36

字符串時間復雜度

2021-09-02 09:22:13

算法無重復字符

2021-09-10 08:31:54

翻轉字符串單詞

2016-12-29 17:14:41

回文串算法代碼

2021-10-29 07:25:32

螺旋矩陣整數(shù)

2021-08-26 05:08:25

相鄰重復項算法

2021-09-27 09:18:30

分割回文串循環(huán)

2021-08-30 14:34:10

有效算法字符

2021-10-28 19:33:36

矩陣圖像內存

2021-11-19 07:54:40

前端

2016-12-29 15:58:00

字符串子串算法

2021-09-30 09:58:14

路徑總和二叉樹

2020-02-04 18:06:28

千年一遇對稱日回文算法

2021-11-04 09:59:03

動態(tài)規(guī)劃策略

2021-10-26 00:23:26

算法高頻元素

2021-10-27 10:43:36

數(shù)據(jù)流中位數(shù)偶數(shù)

2021-09-29 10:19:00

算法平衡二叉樹

2021-09-08 09:52:34

語言

2021-09-15 07:56:32

二叉樹層次遍歷

2021-09-28 06:28:51

二叉樹公共祖先
點贊
收藏

51CTO技術棧公眾號