844. Backspace String Compare

题目的意思大概是有两个字符串,其中的#表示退格键,让比较最后两个字符串是否相当。

很容易想到的思路就是用一个栈进行模拟这个过程,特别需要注意如果一个串是空串也是可以退格的。

但是很容易想到的另一个特性就是,前面的字符有可能被后面的退格符删去,但是如果如果从后往前进行遍历的话那么一个字符一旦保留就不会被删除,我们比较两个字符串保留下来的字符,一旦发现不相等就直接返回。

总体来讲就是双指针加逆序遍历。

其实看到这个题我直接就想到双指针加逆序遍历了。但是昨天晚上也不知道是因为困了还是什么原因,写了二十分钟写的都是错的。关键是对删除的过程理解的不够深刻,我们得到的保留的下来的字符应该有两个特征:

  1. 不是#
  2. 后面没有#来删除它
    抓住这两个特征,如果有一个特征不满足就要继续删除,直到删除过程结束。
    中午写了一下直接过了,果然还是白天头脑清晰一点。
class Solution {
public:
    bool backspaceCompare(string S, string T) {
        int i = S.size()-1; int j = T.size()-1;
        int iNum = 0, jNum = 0;
        while(i>=0 || j>=0)
        {
            while(i>=0 && (S[i]=='#' || iNum > 0))
            {
                if(S[i] == '#') ++iNum;
                else --iNum;
                --i;
            }
            while(j>=0 && (T[j]=='#' || jNum > 0))
            {
                if(T[j] == '#') ++jNum;
                else --jNum;
                --j;
            }
            if(i<0 && j<0) return true;
            if(i<0 && j>=0 || i>=0 && j<0) return false;
            if(S[i] != T[j]) return false;
            --i; --j;
        }
        return true;
    }
};

看了一下题解,大概和题解写的差不多,但是我在上面循环删除部分写的比题解稍微好一点,题解在最后的判断写的比我好。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值