Java中使用一个栈来处理

题目描述

剑指Offer的替换空格

解题思路

新开辟一个栈,然后从尾部向前遍历输入的字符串的每个字符,如果不是空格就直接入栈,如果是空格就依次将'0'、'2'、'%' 入栈。然后通过StringBuffer将栈中的字符连起来就OK啦。

代码实现

import java.util.Stack;
public class Solution {
    public String replaceSpace(StringBuffer str) {
        String str1 = str.toString();

        Stack<Character> res = new Stack<Character>();

        for (int i = str1.length() - 1; i >= 0; i--) {
            char c = str1.charAt(i);
            if (c != ' ') {
                res.push(c);
            } else {
                res.push('0');
                res.push('2');
                res.push('%');
            }
        }

        StringBuffer sb = new StringBuffer();

        while (!res.empty()) {
            sb.append(res.pop());
        }

        return sb.toString();
    }
}
全部评论

相关推荐

点赞 评论 收藏
分享
能干的三文鱼刷了10...:公司可能有弄嵌入式需要会画pcb的需求,而且pcb能快速直观看出一个人某方面的实力。看看是否有面试资格。问你问题也能ai出来,pcb这东西能作假概率不高
点赞 评论 收藏
分享
06-26 15:33
青岛工学院 Java
积极的秋田犬要冲国企:他现在邀请我明天面试
点赞 评论 收藏
分享
“校招”、“3-5年经验”
xiaolihuam...:逆向工程不是搞外挂的吗,好像现在大学生坐牢最多的就是诈骗罪和非法侵入计算机系统罪,发美金,还居家办公,就是怕被一锅端,
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务