精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

數據結構與算法之比較含退格的字符串!

開發 前端 算法
給定 S 和 T 兩個字符串,當它們分別被輸入到空白的文本編輯器后,判斷二者是否相等,并返回結果。# 代表退格字符。

[[441739]]

比較含退格的字符串

力扣題目鏈接:https://leetcode-cn.com/problems/backspace-string-compare

給定 S 和 T 兩個字符串,當它們分別被輸入到空白的文本編輯器后,判斷二者是否相等,并返回結果。# 代表退格字符。

注意:如果對空文本輸入退格字符,文本繼續為空。

示例 1:

  • 輸入:S = "ab#c", T = "ad#c"
  • 輸出:true
  • 解釋:S 和 T 都會變成 “ac”。

示例 2:

  • 輸入:S = "ab##", T = "c#d#"
  • 輸出:true
  • 解釋:S 和 T 都會變成 “”。

示例 3:

  • 輸入:S = "a##c", T = "#a#c"
  • 輸出:true
  • 解釋:S 和 T 都會變成 “c”。

示例 4:

  • 輸入:S = "a#c", T = "b"
  • 輸出:false
  • 解釋:S 會變成 “c”,但 T 仍然是 “b”。

思路

本文將給出 空間復雜度的棧模擬方法 以及空間復雜度是的雙指針方法。

普通方法(使用棧的思路)

這道題目一看就是要使用棧的節奏,這種匹配(消除)問題也是棧的擅長所在,跟著一起刷題的同學應該知道,在棧與隊列:匹配問題都是棧的強項,我就已經提過了一次使用棧來做類似的事情了。

那么本題,確實可以使用棧的思路,但是沒有必要使用棧,因為最后比較的時候還要比較棧里的元素,有點麻煩。

這里直接使用字符串string,來作為棧,末尾添加和彈出,string都有相應的接口,最后比較的時候,只要比較兩個字符串就可以了,比比較棧里的元素方便一些。

代碼如下:

  1. class Solution { 
  2. public
  3.     bool backspaceCompare(string S, string T) { 
  4.         string s; // 當棧來用 
  5.         string t; // 當棧來用 
  6.         for (int i = 0; i < S.size(); i++) { 
  7.             if (S[i] != '#') s += S[i]; 
  8.             else if (!s.empty()) { 
  9.                 s.pop_back(); 
  10.  
  11.         } 
  12.         for (int i = 0; i < T.size(); i++) { 
  13.             if (T[i] != '#') t += T[i]; 
  14.             else if (!t.empty()) { 
  15.                 t.pop_back(); 
  16.             } 
  17.         } 
  18.         if (s == t) return true; // 直接比較兩個字符串是否相等,比用棧來比較方便多了 
  19.         return false
  20.     } 
  21. }; 

時間復雜度:,n為S的長度,m為T的長度 ,也可以理解是的時間復雜度

空間復雜度:當然以上代碼,大家可以發現有重復的邏輯處理S,處理T,可以把這塊公共邏輯抽離出來,代碼精簡如下:

  1. class Solution { 
  2. private: 
  3. string getString(const string& S) { 
  4.     string s; 
  5.     for (int i = 0; i < S.size(); i++) { 
  6.         if (S[i] != '#') s += S[i]; 
  7.         else if (!s.empty()) { 
  8.             s.pop_back(); 
  9.         } 
  10.     } 
  11.     return s; 
  12. public
  13.     bool backspaceCompare(string S, string T) { 
  14.         return getString(S) == getString(T); 
  15.     } 
  16. }; 

性能依然是:

  • 時間復雜度:
  • 空間復雜度:

優化方法(從后向前雙指針)

當然還可以有使用 的空間復雜度來解決該問題。

同時從后向前遍歷S和T(i初始為S末尾,j初始為T末尾),記錄#的數量,模擬消除的操作,如果#用完了,就開始比較S[i]和S[j]。

動畫如下:

如果S[i]和S[j]不相同返回false,如果有一個指針(i或者j)先走到的字符串頭部位置,也返回false。

代碼如下:

  1. class Solution { 
  2. public
  3.     bool backspaceCompare(string S, string T) { 
  4.         int sSkipNum = 0; // 記錄S的#數量 
  5.         int tSkipNum = 0; // 記錄T的#數量 
  6.         int i = S.size() - 1; 
  7.         int j = T.size() - 1; 
  8.         while (1) { 
  9.             while (i >= 0) { // 從后向前,消除S的# 
  10.                 if (S[i] == '#') sSkipNum++; 
  11.                 else { 
  12.                     if (sSkipNum > 0) sSkipNum--; 
  13.                     else break; 
  14.                 } 
  15.                 i--; 
  16.             } 
  17.             while (j >= 0) { // 從后向前,消除T的# 
  18.                 if (T[j] == '#') tSkipNum++; 
  19.                 else { 
  20.                     if (tSkipNum > 0) tSkipNum--; 
  21.                     else break; 
  22.                 } 
  23.                 j--; 
  24.             } 
  25.             // 后半部分#消除完了,接下來比較S[i] != T[j] 
  26.             if (i < 0 || j < 0) break; // S 或者T 遍歷到頭了 
  27.             if (S[i] != T[j]) return false
  28.             i--;j--; 
  29.         } 
  30.         // 說明S和T同時遍歷完畢 
  31.         if (i == -1 && j == -1) return true
  32.         return false
  33.     } 
  34. }; 
  • 時間復雜度:
  • 空間復雜度:

其他語言版本

Java:

  1. // 普通方法(使用棧的思路) 
  2. class Solution { 
  3.     public boolean backspaceCompare(String s, String t) { 
  4.         StringBuilder ssb = new StringBuilder(); // 模擬棧 
  5.         StringBuilder tsb = new StringBuilder(); // 模擬棧 
  6.         // 分別處理兩個 String 
  7.         for (char c : s.toCharArray()) { 
  8.             if (c != '#') { 
  9.                 ssb.append(c); // 模擬入棧 
  10.             } else if (ssb.length() > 0){ // 棧非空才能彈棧 
  11.                 ssb.deleteCharAt(ssb.length() - 1); // 模擬彈棧 
  12.             } 
  13.         } 
  14.         for (char c : t.toCharArray()) { 
  15.             if (c != '#') { 
  16.                 tsb.append(c); // 模擬入棧 
  17.             } else if (tsb.length() > 0){ // 棧非空才能彈棧 
  18.                 tsb.deleteCharAt(tsb.length() - 1); // 模擬彈棧 
  19.             } 
  20.         } 
  21.         return ssb.toString().equals(tsb.toString()); 
  22.     } 

python

  1. class Solution: 
  2.  
  3.     def get_string(self, s: str) -> str : 
  4.         bz = [] 
  5.         for i in range(len(s)) : 
  6.             c = s[i] 
  7.             if c != '#' : 
  8.                 bz.append(c) # 模擬入棧 
  9.             elif len(bz) > 0: # 棧非空才能彈棧 
  10.                 bz.pop() # 模擬彈棧 
  11.         return str(bz) 
  12.  
  13.     def backspaceCompare(self, s: str, t: str) -> bool: 
  14.         return self.get_string(s) == self.get_string(t) 
  15.         pass 

Go

  1. func getString(s string) string { 
  2.  bz := []rune{} 
  3.  for _, c := range s { 
  4.   if c != '#' { 
  5.    bz = append(bz, c); // 模擬入棧 
  6.   } else if len(bz) > 0 { // 棧非空才能彈棧 
  7.    bz = bz[:len(bz)-1] // 模擬彈棧 
  8.   } 
  9.  } 
  10.  return string(bz) 
  11.  
  12. func backspaceCompare(s string, t string) bool { 
  13.  return getString(s) == getString(t) 

 JavaScript

  1. // 雙棧 
  2.  
  3. var backspaceCompare = function(s, t) { 
  4.  
  5. const arrS = [], arrT = []; // 數組作為棧使用 
  6.  
  7. for(let char of s){ 
  8.  
  9. char === '#' ? arrS.pop() : arrS.push(char); 
  10.  
  11.  
  12. for(let char of t){ 
  13.  
  14. char === '#' ? arrT.pop() : arrT.push(char); 
  15.  
  16.  
  17. return arrS.join('') === arrT.join(''); // 比較兩個字符串是否相等 
  18.  
  19. }; 
  20.  
  21. //雙棧精簡 
  22.  
  23. var backspaceCompare = function(s, t) { 
  24.  
  25. const getString = s => { 
  26.  
  27. let arrS = []; 
  28.  
  29. for(let char of s){ 
  30.  
  31. char === '#' ? arrS.pop() : arrS.push(char); 
  32.  
  33.  
  34. return arrS.join(''); 
  35.  
  36.  
  37. return getString(s) === getString(t); 
  38.  
  39. }; 
  40.  
  41. //雙指針 
  42.  
  43. var backspaceCompare = function(s, t) { 
  44.  
  45. let sSkipNum = 0; // 記錄s的#數量 
  46.  
  47. let tSkipNum = 0; // 記錄t的#數量 
  48.  
  49. let i = s.length - 1, j = t.length - 1; 
  50.  
  51. while(true) { 
  52.  
  53. while(i >= 0){ // 從后向前,消除s的# 
  54.  
  55. if(s[i] === '#') sSkipNum++; 
  56.  
  57. else { 
  58.  
  59. if (sSkipNum > 0) sSkipNum--; 
  60.  
  61. else break; 
  62.  
  63.  
  64. i--; 
  65.  
  66.  
  67. while (j >= 0) { // 從后向前,消除t的# 
  68.  
  69. if (t[j] === '#') tSkipNum++; 
  70.  
  71. else { 
  72.  
  73. if (tSkipNum > 0) tSkipNum--; 
  74.  
  75. else break; 
  76.  
  77.  
  78. j--; 
  79.  
  80.  
  81. // 后半部分#消除完了,接下來比較s[i] != t[j] 
  82.  
  83. if (i < 0 || j < 0) break; // s 或者t 遍歷到頭了 
  84.  
  85. if (s[i] !== t[j]) return false
  86.  
  87. i--;j--; 
  88.  
  89.  
  90. // 說明s和t同時遍歷完畢 
  91.  
  92. if (i == -1 && j == -1) return true
  93.  
  94. return false
  95.  
  96. }; 

 

責任編輯:姜華 來源: 今日頭條
相關推薦

2021-12-21 11:39:01

數據結構算法同構字符串

2021-12-24 11:59:47

數據結構算法字符串

2023-03-13 10:08:31

數據結構算法

2020-10-21 14:57:04

數據結構算法圖形

2023-03-08 08:03:09

數據結構算法歸并排序

2023-10-27 07:04:20

2023-04-27 09:13:20

排序算法數據結構

2019-03-07 15:43:22

Redis數據SDS

2023-03-07 08:02:07

數據結構算法數列

2023-03-02 08:15:13

2023-03-10 08:07:39

數據結構算法計數排序

2020-09-28 08:11:14

JavaScript數據

2023-10-19 15:11:48

Redis

2023-09-25 12:23:18

Python

2021-01-28 07:33:34

JavaScript鏈表數據

2016-08-21 14:19:05

數據工具DataXSqoop

2023-02-08 07:52:36

跳躍表數據結構

2023-10-30 08:31:42

數據結構算法

2023-11-06 06:43:23

單鏈表查詢數據結構

2017-08-31 09:45:43

JavaArrayList數據
點贊
收藏

51CTO技術棧公眾號

91资源在线观看| jlzzjlzzjlzz亚洲人| 婷婷亚洲精品| 欧美三级视频在线| 亚洲第一综合网站| 日本精品999| www.在线视频| 成人亚洲一区二区一| 日本在线精品视频| 日韩在线中文字幕视频 | 国产精品亚洲精品| 精品一区二区三区四| 欧美日本成人| 精品少妇一区二区三区免费观看| 欧美日韩亚洲第一| 影音先锋在线播放| 中文字幕欧美国产| 欧美黄色成人网| 少妇精品一区二区三区| 亚洲欧美在线人成swag| 欧美日韩在线视频一区二区| 亚洲成年人专区| 日本成人一区| 国产盗摄精品一区二区三区在线 | 最新中文字幕在线观看视频| 欧美日韩精品一本二本三本| 中文字幕亚洲国产| 亚洲国产果冻传媒av在线观看| 四虎国产精品免费久久| 色一情一乱一乱一91av| 福利视频一区二区三区四区| 成人国产免费电影| 中文字幕免费一区| 日本视频一区在线观看| 无码h黄肉3d动漫在线观看| 日韩激情视频网站| 青草热久免费精品视频| 国产精品6666| 欧美三级不卡| 欧美老女人xx| 精品国产精品国产精品| 日韩欧美综合| 少妇av一区二区三区| 51妺嘿嘿午夜福利| 国产精品欧美日韩一区| 日韩精品高清视频| av2014天堂网| 任你躁在线精品免费| 精品少妇一区二区三区在线播放| 在线a免费观看| 天堂综合在线播放| 欧美日韩国产影片| 色天使在线观看| 四虎国产精品成人免费影视| 欧美日韩国产美| 波多野结衣xxxx| 老司机精品视频网| 欧美日韩aaaaa| 欧美一级特黄aaa| 国产精品国产三级在线观看| 欧美另类videos死尸| 欧美美女一级片| 亚洲精品一区二区在线播放∴| 欧美日韩一区二区三区不卡 | 国产精品1区2区| 成人女保姆的销魂服务| 夜夜狠狠擅视频| 精品一区二区三区的国产在线播放 | 无码 人妻 在线 视频| 免费日韩一区二区三区| 亚洲精品在线视频| 欧美bbbbb性bbbbb视频| 国产精品一区二区三区av麻| 国产亚洲精品激情久久| 成年人视频软件| 综合久久久久| 久久男人资源视频| 中文字幕第四页| 琪琪一区二区三区| 亚洲一区制服诱惑| 日本波多野结衣在线| 久久久欧美精品sm网站| 日韩欧美亚洲区| 国产秀色在线www免费观看| 亚洲尤物在线视频观看| 黄色动漫网站入口| 日韩黄色碟片| 亚洲国产精品免费| 欧美激情久久久久久久| 精品盗摄女厕tp美女嘘嘘| 亚洲欧美日韩在线高清直播| 来吧亚洲综合网| 精品电影一区| 国产精品入口福利| 亚洲精品久久久久久无码色欲四季| 91蜜桃传媒精品久久久一区二区| 深田咏美在线x99av| jizz性欧美| 色婷婷av一区| 少妇伦子伦精品无吗| 久久不见久久见国语| 久久久国产一区| www.com国产| 国产91精品一区二区| 国外成人在线播放| 这里只有精品999| 成人永久免费视频| 先锋影音亚洲资源| 高清视频在线观看三级| 欧美片网站yy| 欧美图片一区二区| 在线观看视频免费一区二区三区| 国产精品免费视频xxxx| 四虎永久在线观看| 成人免费毛片嘿嘿连载视频| 色阁综合av| 麻豆免费在线| 天涯成人国产亚洲精品一区av| 青青青在线视频免费观看| 成人免费直播在线| 久久精品久久精品亚洲人| 欧美h在线观看| 国产凹凸在线观看一区二区| 亚洲精品自在在线观看| 樱花草涩涩www在线播放| 欧美一二三区在线观看| 粉嫩精品久久99综合一区| 99亚洲视频| www 成人av com| 欧美性猛交xxx乱大交3蜜桃| 色综合天天狠狠| 在线免费看黄色片| 欧美/亚洲一区| 国产日韩专区在线| 波多野结衣在线网站| 一本色道久久综合亚洲91| 一区二区免费在线观看视频| 欧美国产91| 亚洲最大的av网站| 在线观看中文字幕的网站| 欧美剧在线免费观看网站| 亚洲av成人无码久久精品| 免费日韩视频| 激情欧美一区二区三区中文字幕| 三级网站视频在在线播放| 欧美一级二级三级乱码| 久久久久久久久久网站| 国产一区二区三区在线看麻豆| 一区二区三区欧美成人| 99久久综合国产精品二区| 亚洲一区二区久久久| 国产免费a视频| 中文字幕成人网| 色播五月综合网| 天天射天天综合网| 亚洲va电影大全| 欧美14一18处毛片| 精品成人a区在线观看| 九九热国产视频| 99久久99久久精品国产片果冻| 国产精品999视频| 天天做夜夜做人人爱精品| 青草成人免费视频| 亚洲麻豆精品| 日韩欧美一区二区久久婷婷| 欧美精品99久久久| 成人va在线观看| 自慰无码一区二区三区| 久久成人高清| 成人网中文字幕| av丝袜在线| 亚洲欧美精品一区二区| 中文字幕+乱码+中文乱码www| 国产精品午夜电影| 欧美日韩一区二区区| 亚洲高清免费| 色综合久久88色综合天天提莫| 国产午夜久久av| 久久全球大尺度高清视频| 欧美偷拍视频| 欧美另类久久久品| 成人午夜视频精品一区| 国产目拍亚洲精品99久久精品 | 国产精品一区二区三区四区| 国产一线二线三线女| 自拍自偷一区二区三区| 国产女同一区二区| 久草在线视频福利| 亚洲美女激情视频| 国产情侣av在线| 欧美日韩中文字幕在线视频| а天堂中文在线资源| 成人久久18免费网站麻豆 | 国产精品一二三四| 国产成人a亚洲精v品无码| 999久久久免费精品国产| 国产99视频精品免费视频36| 日产精品一区| 欧美激情极品视频| 爱爱爱免费视频在线观看| 精品久久久久一区二区国产| 午夜视频网站在线观看| 亚洲成人你懂的| 国产极品视频在线观看| 99麻豆久久久国产精品免费优播| 欧美日韩中文不卡| 国产精品五区| 国产精品无码电影在线观看| 成久久久网站| 韩日午夜在线资源一区二区| 国产日本亚洲| 国产精品旅馆在线| 天堂中文在线播放| 欧美精品在线极品| 人人干在线视频| 亚洲美女精品久久| 色一情一乱一乱一区91av| 4438成人网| 国产精品xxxxxx| 欧美性xxxxxxx| 国产成人精品亚洲男人的天堂| 亚洲桃色在线一区| 国产综合精品久久久久成人av| 99亚偷拍自图区亚洲| 一起草最新网址| 精品亚洲欧美一区| 2025韩国理伦片在线观看| 亚洲综合日本| 久色视频在线播放| 亚洲黄页一区| 成人小视频在线观看免费| 亚洲成人精选| 中文字幕一区二区中文字幕| 日韩欧美视频在线播放| 日韩精品在在线一区二区中文| 日本精品影院| 精品日韩电影| 日韩丝袜视频| 蜜桃狠狠色伊人亚洲综合网站| 国产精品任我爽爆在线播放| 成人国产一区二区| aiai久久| 国产欧美日韩亚洲| 欧美尿孔扩张虐视频| 国产一区高清视频| 欧美日韩麻豆| 欧美精品免费观看二区| 亚洲动漫精品| 日韩av影视| 人人狠狠综合久久亚洲婷婷 | 欧美色图麻豆| 国产一区二区四区| 亚洲精品系列| 免费无遮挡无码永久视频| 国产色综合网| 国产精品动漫网站| 日韩av在线免费观看不卡| 亚欧在线免费观看| 琪琪一区二区三区| 激情文学亚洲色图| 国产不卡在线一区| 黄色av网址在线观看| 91麻豆swag| 丁香花五月婷婷| 中文字幕在线免费不卡| 玖玖爱这里只有精品| 亚洲一区在线观看网站| 日韩av在线电影| 91久久免费观看| 亚洲天堂自拍偷拍| 日韩欧美色综合| 天天操天天插天天射| 亚洲免费小视频| 欧美边添边摸边做边爱免费| 欧美成人免费视频| 日韩激情电影| 国产欧美一区二区三区在线 | 欧美影视一区二区| 亚洲乱码在线| 俄罗斯av网站| 久久国产精品免费| 国产午夜在线一区二区三区| 国产日韩欧美电影| 精品欧美一区二区久久久久| 精品动漫一区二区三区| 中文字幕av无码一区二区三区| 欧美一级一区二区| 免费在线视频一级不卡| 久久精品在线播放| 麻豆免费在线| 91系列在线观看| 一道本一区二区三区| 国产一区一区三区| 久久在线精品| 在线观看你懂的视频| 久久蜜桃av一区精品变态类天堂 | 精品人伦一区二区三电影 | 香蕉视频免费版| 午夜一区不卡| 亚洲少妇一区二区| 国产精品系列在线| 国产成人亚洲精品自产在线| 7777女厕盗摄久久久| 久热av在线| 久久久久久12| 成人精品视频在线观看| 久久久精品动漫| 亚洲视屏一区| 一级片黄色免费| 国产精品美女久久久久aⅴ国产馆| 日本三级视频在线| 制服丝袜av成人在线看| 精品久久av| 9.1国产丝袜在线观看| 欧美一级片网址| 亚洲一区二区三区乱码| 性色av一区二区怡红| 久久久久久久久久影视| 中文字幕制服丝袜成人av| 国产91精品看黄网站在线观看| 欧美本精品男人aⅴ天堂| 欧美性videos| 国产精品一区=区| 国产尤物久久久| 日本不卡在线观看视频| 99综合电影在线视频| 精品无码久久久久久久久| 欧美一区三区四区| 免费**毛片在线| 国产欧美中文字幕| av亚洲免费| 手机在线免费观看毛片| 国产午夜亚洲精品理论片色戒 | 激情伊人五月天久久综合| av女人的天堂| 日本精品视频一区二区| 日韩av资源| 欧美整片在线观看| 色综合www| 日本精品www| 久久久亚洲高清| 中文字幕免费高清网站| 国产一区二区三区高清在线观看| 美女一区网站| 欧美亚州在线观看| 日韩精品电影一区亚洲| 亚洲女优在线观看| 欧美视频一区二| 香蕉视频在线看| 成人亚洲激情网| 亚洲精品久久| 风韵丰满熟妇啪啪区老熟熟女| 亚洲最大成人网4388xx| 亚洲国产精品欧美久久| 久久久视频在线| 日韩精品导航| 日本男人操女人| 国产精品欧美极品| 国产精品特级毛片一区二区三区| 久久这里只有精品视频首页| 精品国产一区二| 久色视频在线播放| 国产三级一区二区| 国产精品视频无码| 欧美激情乱人伦一区| 欧美日韩一本| www.色偷偷.com| 亚洲免费在线视频一区 二区| www.五月激情| 欧美一区三区三区高中清蜜桃| 蜜桃精品wwwmitaows| 玖玖爱视频在线| 亚洲成人免费看| 国产在线观看黄| 91亚洲国产成人久久精品网站| 国产精品a级| av黄色在线免费观看| 欧美久久久久久久久久| 欧美寡妇性猛交xxx免费| 美脚丝袜一区二区三区在线观看| 日本不卡不码高清免费观看| 欧美成人精品欧美一| 亚洲男人7777| 97久久精品一区二区三区的观看方式 | 91在线视频导航| 日韩香蕉视频| 蜜桃av免费观看| 亚洲精品一区二区三区99| 电影亚洲精品噜噜在线观看| 福利网在线观看| wwwwww.欧美系列| 99热这里只有精品99| 日本韩国在线不卡| 一区二区不卡| 亚洲一区二区三区日韩| 亚洲精品一区二区三区影院 | 久久噜噜色综合一区二区| 亚洲精品久久7777777| 一级欧美视频| 日韩中文字幕二区|