首页 > 其他分享 >844.比较含退格的字符串

844.比较含退格的字符串

时间:2024-10-08 23:46:41浏览次数:15  
标签:844 return -- else skipS while skipT 字符串 退格

题目:844. 比较含退格的字符串 - 力扣(LeetCode)

思路:首先要知道这个#的意思是可以将前面一个数清空,(当时 我以为是将前面一串清空。。。看了半天),由于 # 号只会消除左边的一个字符,所以对右边的字符无影响,所以我们选择从后往前遍历 S,T 字符串,以skipS和T去记录,可以清空前面的数,实际上也是在两个数组中移动,用了双指针算法

图示:

代码:

class Solution {
public:
    bool backspaceCompare(string S, string T) {
       int i = S.length()-1,j = T.length()-1;
       int skipS = 0,skipT = 0;
       while(i >= 0 || j >= 0)
       {
          while(i >= 0)
          {
             if(S[i] == '#')
             skipS++,i--;
             else if(skipS > 0)
             skipS--,i--;
             else break;
          }
           while(j >= 0)
          {
            if(T[j] == '#')
             skipT++,j--;
             else if(skipT > 0)
             skipT--,j--;
             else break;
          }
          if( i>=0 && j>=0 ){
            if(S[i]!=T[j])
            return false;
          }
          else
          {
            if(i>=0 || j>=0)
            return false;
          }
          i--,j--;
       }
    return true;
    }
};

标签:844,return,--,else,skipS,while,skipT,字符串,退格
From: https://blog.csdn.net/zengxuan151168/article/details/142772124

相关文章

  • 代码随想录算法训练营day9|●151.翻转字符串里的单词 ●卡码网:55.右旋转字符串 ●28.
    学习资料:https://programmercarl.com/0151.翻转字符串里的单词.html学习记录:151.翻转字符串里的单词(感觉C语言能考虑巧妙解法,而python直接搞就对了)c语言:把字符串整体反转,再用双指针法(slow,fast)依次翻转每一个单词,关键在于如何移除多余空格,用slow指针找到要替换到的位置,用fast......
  • Python 字符串基础知识
    字符串是计算机编程中非常重要的数据类型。在Python中,字符串是一系列字符的集合,可以包含字母、数字、符号和空格。Python提供了强大的字符串处理功能,使得操作字符串变得简单而直观。本文将深入探讨Python字符串的基本知识,包括字符串的创建、操作、常用方法以及字符串格式......
  • Python字符串打印格式
    一、旧式字符串格式化(%格式)在Python中,最早的字符串格式化方法是使用百分号(%)操作符。这种方式可以追溯到C语言,因此对于习惯于C语言的程序员来说是比较熟悉的。1.基本用法基本语法如下:name="Alice"age=30print("Mynameis%sandIam%dyearsold."%(name,age)......
  • 递归_字符串匹配,最长连续序列
    1:字符串匹配题目链接:LCR137.模糊搜索验证-力扣(LeetCode)可以使用递归的方法来检查 input 是否可以匹配 article。目的是正确处理两种通配符:‘.’和‘*’的匹配规则。defis_match(article:str,input:str)->bool:ifnotinput:returnnotarticle......