博客
关于我
替换空格
阅读量:175 次
发布时间:2019-02-28

本文共 1879 字,大约阅读时间需要 6 分钟。

请实现一个函数,将一个字符串中的每个空格替换成“%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 11w 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 15w 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();    }}

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

转载地址:http://kphc.baihongyu.com/

你可能感兴趣的文章
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>
mysql_secure_installation初始化数据库报Access denied
查看>>
MySQL_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>