每天一道算法题(三)----二维数组中的查找

博客提出将字符串中每个空格替换成“%20”的问题,给出了不同语言的解题思路。使用Java可借助StringBuffer对象的indexOf函数替换;C/C++可从前往后找空格,后移元素插入“%20”,还可通过空间换时间,分割字符串后拼接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

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

条件:时间限制:1秒 空间限制:32768K 热度指数:1030743

我的解题思路:

     1. 使用java语言有好用的封装的类库,使用StringBuffer对象的indexOf函数寻找空格,并且将其替换为“%20”,直到字符串李没有空格为止。使用java实现起来比较简单,如下代码:

     2. 使用C/C++解题思路:

       (1)字符串使用char * str来存储,从字符第一个元素开始找,找到第一个空格,将空格之后的元素都往后移两位,在空格处插入字符串“%20”;

       (2)继续往后寻找空格,重复(1)操作,直到遇到字符串结束符,返回替换后结果。

      3. 使用C/C++解题思路优化(空间换时间的方式): 实现字符串的split函数,将字符串按空格分割成多个字符串,并把这些字符串在字符串尾部插入“%20”后,存储到vector里;最后将vector里的字符串按顺序取出并且进行拼接。

public class Solution {
    public String replaceSpace(StringBuffer str) {
    	 while(str.indexOf(" ") != -1) {
            int start = str.indexOf(" ");
            str = str.replace(start, start+1, "%20");
        }
        return new String(str);
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值