力扣刷题——844.比较含退格的字符串

给定 st 两个字符串,当它们分别被输入到空白的文本编辑器后,如果两者相等,返回 true# 代表退格字符。

**注意:**如果对空文本输入退格字符,文本继续为空。

示例 1:

复制代码
输入:s = "ab#c", t = "ad#c"
输出:true
解释:s 和 t 都会变成 "ac"。

虽然是一道easy题,但是要做到O(1)的额外空间,就不能使用暴力解法

于是我思考,两个数组都从后往前遍历,当出现'#'字符时,可以记录它出现的次数,从而进行退格操作

第一次提交代码

cpp 复制代码
class Solution {
public:
    bool backspaceCompare(string s, string t) {
        int slen=s.size();
        int tlen=t.size();
        int i=slen-1;
        int j=tlen-1;
        while(i>=0||j>=0)
        {
           
            int n1=0,n2=0;
            while(i>=0&&s[i]=='#')
            {
                n1++;
                i--;
            }
            while(i>=0&&n1>0)
            {
                
                if(s[i]=='#') n1++;
                else n1--;
                i--;
            }
             while(j>=0&&t[j]=='#')
            {
                n2++;
                j--;
            }
            while(j>=0&&n2>0)
            {
                
                if(t[j]=='#') n2++;
                else n2--;
                j--;
            }
           
            if (i >= 0 && j >= 0) {
            if (s[i] != t[j]) {
                return false;
            }
        }

            i--;
            j--;
        }

        return true;
    }
};

结果是,我没有正确处理一个字符串已经遍历完,而另一个字符串还有字符的情况。当 ij 其中一个小于 0 时,代码没有进行相应的判断,就直接继续循环,可能会导致错误的结果。例如,当 s 已经处理完所有有效字符(i < 0),而 t 还有有效字符(j >= 0)时,应该返回 false,但当前代码没有处理这种情况。

修改后

cpp 复制代码
class Solution {
public:
    bool backspaceCompare(string s, string t) {
        int slen=s.size();
        int tlen=t.size();
        int i=slen-1;
        int j=tlen-1;
        int n1=0,n2=0;
        while(i>=0||j>=0)
        {
           
            
           
            while(i>=0)
            {
                
                if(s[i]=='#') n1++,i--;
                else if(n1>0) n1--,i--;
                else break;
            }
            
            while(j>=0)
            {
                
                if(t[j]=='#') n2++,j--;
                else if(n2>0) n2--,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;
    }
};
相关推荐
虾球xz1 小时前
游戏引擎学习第276天:调整身体动画
c++·学习·游戏引擎
虾球xz1 小时前
游戏引擎学习第275天:将旋转和剪切传递给渲染器
c++·学习·游戏引擎
AndrewHZ1 小时前
【图像处理基石】什么是油画感?
图像处理·人工智能·算法·图像压缩·视频处理·超分辨率·去噪算法
.格子衫.1 小时前
015枚举之滑动窗口——算法备赛
数据结构·算法
J先生x2 小时前
【IP101】图像处理进阶:从直方图均衡化到伽马变换,全面掌握图像增强技术
图像处理·人工智能·学习·算法·计算机视觉
爱coding的橙子4 小时前
每日算法刷题 Day3 5.11:leetcode数组2道题,用时1h(有点慢)
算法·leetcode
虾球xz6 小时前
游戏引擎学习第268天:合并调试链表与分组
c++·学习·链表·游戏引擎
fpcc6 小时前
跟我学c++高级篇——模板元编程之十三处理逻辑
c++
格林威7 小时前
Baumer工业相机堡盟工业相机的工业视觉中为什么偏爱“黑白相机”
开发语言·c++·人工智能·数码相机·计算机视觉
Dream it possible!8 小时前
LeetCode 热题 100_只出现一次的数字(96_136_简单_C++)(哈希表;哈希集合;排序+遍历;位运算)
c++·leetcode·位运算·哈希表·哈希集合