844. Backspace String Compare

本文介绍了一种使用栈数据结构实现的字符串比较算法,该算法能够处理包含退格字符('#')的字符串,通过逐个字符处理并利用栈进行退格操作,最终比较两个字符串是否相等。文章详细展示了算法的实现过程,包括栈的初始化、字符处理流程及比较逻辑。

 

class Solution {
    public boolean backspaceCompare(String S, String T) {
       
        if (S == null || T == null)   return false;
        Stack<Character> stackS = new Stack<Character>();
        Stack<Character> stackT = new Stack<Character>();
        
        handleStack(S.toCharArray(), stackS);
        handleStack(T.toCharArray(), stackT);
        
       if (stackS.size() != stackT.size()) return false;
       if (stackS.size() == stackT.size()) { //Stack inherit size() from Vector class : java.util.Vector.size()
           while (!stackS.isEmpty()) {
               if (stackS.pop() != stackT.pop()) {
               return false;
                }
            }
       }
        return true;
    }
           
          
   
   private void handleStack(char[] x,Stack stackX) { //Use char[] due to S.toCharArray() it array.debug it on Eclipse
       for (char c : x) {
           if (c == '#') { //don't use "" due to char in " " would be taken as String,not char.Use ' '
               if (!stackX.isEmpty()) {
                   stackX.pop();
               }               
           } else stackX.push(c);              
           }
        }
    }   

Note:

Stack<Character> stackS = new Stack();

        int a = stackS.size();

int java.util.Vector.size()

Returns the number of components in this vector.

Specified by: size() in List, Overrides: size() in AbstractCollection

Returns:

the number of components in this vector
 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值