• 替换空格



    请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy


    解法一:直接调用函数

    这种做法面试官看了直呼内行,然后反手把你挂了

    public class Solution {
        public String replaceSpace(StringBuffer str) {
         return str.toString().replaceAll(" " , "%20");
        }
    }
    

    解法二:

    构造一个新的字符串,遍历原字符串,把字符依次挪到新字符串,遇到空格就换成题目要求的新字符

    public class Solution {
        public String replaceSpace(StringBuffer str) {
            StringBuffer newStr = new StringBuffer();
            for(int i = 0; i < str.length(); i++) {
                if(str.charAt(i) != ' ') {
                    newStr.append(str.charAt(i));
                } else {
                    newStr.append("%20");
                }
            }
            return newStr.toString();
        }
    }
    

    解法三:

    从前向后记录空格的数目,从后向前替换空格

    0 1 2 3 4 5 6 7 8 9 10 11
    w e   a r e   l u c  k  y
    

    假设空格的个数为 count,可以得知 count 为 2,所以在替换的时候,下标 7 ~ 11 的字母要向后移动 count × 2 个位置,3 ~ 5 字母要向后移动 (count - 1) × 2 个位置。 所以得到 :

    0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
    w e   a r e   l u c  k y 
    w e       a r e        l   u  c  k  y
    

    这时就可以直接在空格处写入 %20 了

    public class Solution {
        public String replaceSpace(StringBuffer str) {
            // 计算空格数
            int spaceCount = 0;
            for(int i = 0; i < str.length(); i++) {
                if (str.charAt(i) == ' ') {
                    spaceCount++;
                }
            }
            // 保存下标
            int index = str.length() - 1;
            // 扩大长度
            str.setLength(str.length() + spaceCount*2);
            while (index >= 0) {
                if (str.charAt(index) != ' ') {
                    str.setCharAt(index + spaceCount * 2, str.charAt(index));
                } else {
                    spaceCount--;
                    str.setCharAt(index + spaceCount * 2, '%');
                    str.setCharAt(index + spaceCount * 2 + 1, '2');
                    str.setCharAt(index + spaceCount * 2 + 2, '0');
                }
                index--;
            }
            return str.toString();
        }
    }
    

    总结:字符替换类的题目,要大胆假设,不要觉得想法过于复杂就放弃思考


  • 相关阅读:
    统计学(第六版)14单元——学习总结
    统计学(第六版)13单元——学习总结(时间序列分析总结)
    统计学(第六版)11到12单元——学习总结
    Kubernetes: 微内核的分布式操作系统
    彻底搞懂JavaScript之原型
    手把手带你玩转k8s-一键部署vue项目
    新一代缓存Caffeine,速度确实比Guava的Cache快
    理解 Es6 中的 Symbol 类型
    一天一大 leet(用两个栈实现队列)难度:简单 DAY-30
    (Java 源码阅读) 春眠不觉晓,HashMap知多少
  • 原文地址:https://www.cnblogs.com/Yee-Q/p/13655980.html
Copyright © 2020-2023  润新知