[LeetCode-面试01.03]URL化

一.题目描述:

URL化。编写一种方法,将字符串中的空格全部替换为%20。假定该字符串尾部有足够的空间存放新增字符,并且知道字符串的“真实”长度。(注:用Java实现的话,请使用字符数组实现,以便直接在数组上操作。)

示例1:
输入:"Mr John Smith    ", 13
输出:"Mr%20John%20Smith"

示例2:
输入:"               ", 5
输出:"%20%20%20%20%20"

提示:
字符串长度在[0, 500000]范围内。

二.题解

1.方法一
(1)解题思路:
  • 新建一个StringBuilder sb
  • 用for循环遍历,结束条件是小于length
  • 遍历字符串S的第i个字符
  • 当字符为空格时,sb新增元素%20
  • 否则将S的第i个元素加到sb后面
  • 循环结束,将sb转化为String返回即可
(2)代码:
public static String replaceSpaces(String S,int length){
    StringBuilder sb = new StringBuilder();

    for(int i=0;i<length;i++){
       if(S.charAt(i)==' '){
           sb.append("%20");
       }else {
           sb.append(S.charAt(i));
       }
    }
    return sb.toString();
}
2.方法二:
(1)解题思路:
  • 已知字符串后面是空格,,所以将要转化的字符串除了后面的截取
  • 然后再将截取后的字符串中的空格替换为%20即可
(2)代码:
public static String replaceSpaces2(String S,int length){
    String s1 = S.substring(0,length);
    String s2 = S.replaceAll(" ","%20");
    return s2;
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值