赛码网--行编辑器(Java实现)(栈)

题目描述

你知道行编辑器吗?不知道也没关系,现在我会告诉你:1如果你收到一个‘#’,那么你应该删掉一个你已经收到的字符,不包括‘#’;2如果你收到‘@’,那么你应该把你收到的一整行都删掉。(‘#’和‘@’都为不可见字符。)你明白了吗?现在轮到你去解决这个问题啦!

输入

 

第一行是一个整数T,代表有T组数据。
每组数据的开始时一个字符串,字符串长度小于100,每个字符一定是合法字符。

样例输入

 

3

whli##ilr#e(s#*s)

outcha@putchar(*s=#++)

returnWA##A!!##C

 

 

 

输出

 

每组数据输出一行经过行编辑器编辑过的字符串,具体可以看样例。

 

样例输出

 

while(*s)

putchar(*s++)

returnAC

 

解题思路:刚开始的时候,题目是这样的。

表示一脸懵逼。。。从网上找了下这个题目的原版,就在上面了。这个题目用栈解决比较容易,最后把结果反转一下就可以了。

前段时间刚整理过字符串反转的博客,也算是起了点作用啊。。。

地址:https://blog.csdn.net/yong_zi/article/details/81450281

代码:

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int N =sc.nextInt();
        String line = sc.nextLine();
        for(int k=0;k<N;k++){
            String s  = sc.nextLine();
            Stack<Character> stack = new Stack<Character>();
            String res = "";
            for(int i=0;i<s.length();i++){
                if(s.charAt(i) == '#'){
                    if (!stack.empty()){
                        char c = stack.pop();
                    }
                }else if(s.charAt(i)=='@'){
                    while(!stack.empty()){
                        char c = stack.pop();
                    }
                }else{
                    stack.push(s.charAt(i));
                }
            }
            while (!stack.empty()){
                res+=stack.pop();
            }
            System.out.println(new StringBuffer(res).reverse().toString());
        }
    }
}

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值