先把字符串转换为单个字符
这里让求的是把字符串中的空格替换成%20,其中一种实现方式就是申请一个临时数组,然后再遍历这个字符串的每个字符,如果不是空格就把遍历的字符添加到临时数组中,如果是空格就添加3个字符'%','2','0'分别到临时数组中,最后再把临时数组转化为字符串即可。
public String replaceSpace(String s) { int length = s.length(); char[] array = new char[length * 3]; int index = 0; for (int i = 0; i < length; i++) { char c = s.charAt(i); if (c == ' ') { array[index++] = '%'; array[index++] = '2'; array[index++] = '0'; } else { array[index++] = c; } } String newStr = new String(array, 0, index); return newStr; }
时间复杂度:O(n),所有字符都遍历一遍
空间复杂度:O(n),需要一个n*3的数组
看一下运行结果
使用StringBuilder
还有一种方式和上面差不多,就是把字符串中的每个字符一个个添加到StringBuilder中,如果遇到空格就把他换成%20。
public String replaceSpace(String s) { StringBuilder stringBuilder = new StringBuilder(); for (int i = 0; i < s.length(); i++) { if (s.charAt(i) == ' ') stringBuilder.append("%20"); else stringBuilder.append(s.charAt(i)); } return stringBuilder.toString(); }
时间复杂度:O(n),所有字符都遍历一遍
空间复杂度:O(n),StringBuilder需要的空间
看一下运行结果
截止到目前我在公众号“数据结构和算法”中已经写了500多道算法题,其中部分已经整理成了pdf文档,目前总共有1000多页(并且还会不断的增加),大家可以免费下载
下载链接:https://pan.baidu.com/s/1hjwK0ZeRxYGB8lIkbKuQgQ
提取码:6666