




Sponsored
Sponsored
This approach simulates the typing process using two stacks, one for each string. We iterate over each string, using the stack to build the string as it would appear after considering the backspace characters ('#'). By comparing the final stack representations, we can determine if the two strings are equivalent.
Time Complexity: O(n + m), where n and m are the lengths of s and t. Each character is processed once.
Space Complexity: O(n + m) due to the auxiliary arrays used to store the processed results of s and t.
1#include <iostream>
2#include <stack>
3#include <string>
4
5using namespace std;
6
7string buildFinalString(const string &str) {
8    stack<char> s;
9    for (char ch : str) {
10        if (ch != '#') {
11            s.push(ch);
12        } else if (!s.empty()) {
13            s.pop();
14        }
15    }
16    string result;
17    while (!s.empty()) {
18        result += s.top();
19        s.pop();
20    }
21    reverse(result.begin(), result.end());
22    return result;
23}
24
25bool backspaceCompare(string s, string t) {
26    return buildFinalString(s) == buildFinalString(t);
27}
28
29int main() {
30    cout << backspaceCompare("ab#c", "ad#c") << endl; // true
31    cout << backspaceCompare("ab##", "c#d#") << endl; // true
32    cout << backspaceCompare("a#c", "b") << endl;   // false
33    return 0;
34}This C++ solution uses a stack to simulate building the final string. We iterate through the string and push characters onto the stack unless it's a '#', in which case we pop the top character if the stack is not empty. Finally, we reverse the stack's contents to get the built string and compare the two results for equality.
This approach avoids extra space by using two pointers to traverse the strings backwards. By skipping over characters that are effectively backspaced due to a '#' character, we can compare corresponding positions in each string without actually building the resultant strings.
Time Complexity: O(n + m), where n and m are the lengths of s and t.
Space Complexity: O(1), since we only use constant space.
1
class Program {
    static bool BackspaceCompare(string s, string t) {
        int si = s.Length - 1, ti = t.Length - 1;
        int skipS = 0, skipT = 0;
        while (si >= 0 || ti >= 0) {
            while (si >= 0) {
                if (s[si] == '#') { skipS++; si--; }
                else if (skipS > 0) { skipS--; si--; }
                else break;
            }
            while (ti >= 0) {
                if (t[ti] == '#') { skipT++; ti--; }
                else if (skipT > 0) { skipT--; ti--; }
                else break;
            }
            if ((si >= 0 && ti >= 0 && s[si] != t[ti]) || ((si >= 0) != (ti >= 0))) {
                return false;
            }
            si--; ti--;
        }
        return true;
    }
    static void Main(string[] args) {
        Console.WriteLine(BackspaceCompare("ab#c", "ad#c")); // true
        Console.WriteLine(BackspaceCompare("ab##", "c#d#")); // true
        Console.WriteLine(BackspaceCompare("a#c", "b"));   // false
    }
}This C# solution employs a two-pointer method. By moving pointers from the end to the front of the strings, it handles backspaces in constant space without actually modifying the input strings themselves. Characters are checked for equality only after confirming they are the visible characters after simulating backspace deletions.