剑指offer系列--2.字符串操作,将空格替换为其他字符

2.字符串操作,将空格替换为其他字符

一、问题描述:

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

二、解决方案

1、使用java API,replace方法
	public String replaceSpace1(StringBuffer str) {
		if(str==null){
			return null;
		}
		/**
		 *  replace方法的参数
		 *  	--参数1:要替换的字符串
		 *  	--参数2:要替换成什么?
		 */	
		return str.toString().replace(" ", "%20");	  	
    }

2、新开一个字符串
  • 遍历老字符串,遇空格替换,遇其它字符复制
	public String replaceSpace(StringBuffer str) {
		if(str==null){
			return null;
		}
		StringBuilder rs =new StringBuilder();
		for(int i=0;i<str.length();i++){
			if(str.charAt(i)==' '){
				rs.append("%20");
			}else{
				rs.append(str.charAt(i));
			}		
		}
		return rs.toString();    	
    }

3、在旧字符串上操作
  • 获取空格数量
  • 计算新串长度
  • 对旧串进行扩容
  • 两个指针分别指向新旧字符串的末尾
  • 双指针逐步向前移动
public String replaceSpace(StringBuffer str) {
        // 空格数量长度
        int spacenum = 0;	
        for(int i = 0; i < str.length(); i++){
            if(str.charAt(i) == ' '){
                spacenum++;
            }
        }		
        int oldLength = str.length();
        // 指向老字符串末尾
        int oldIndex = oldLength - 1;	
        int newLength = oldLength + spacenum*2;
        // 对字符串进行扩容操作
		str.setLength(newLength);	
        int newIndex = newLength - 1;	
        for(; oldIndex >= 0 && oldLength < newLength; oldIndex--){
            if(str.charAt(oldIndex) == ' '){
                str.setCharAt(newIndex--, '0');
                str.setCharAt(newIndex--, '2');
                str.setCharAt(newIndex--, '%');
            }else{
                str.setCharAt(newIndex--, str.charAt(oldIndex));
            }
        }
        return str.toString();
    }

利用StringBuffer现有的api也能在老字符串上操作

	// 在老字符串上操作
	public static String replaceSpace2(StringBuffer str) {
		/**
		 * --从前往后
		 * 	--遇到空格,先删除,后插入;
		int i=0;
		char[] str1={'%','2','0'};
		while(i<str.length()){
			if(str.charAt(i)==' '){
				str.delete(i, i+1);
				str.insert(i, str1);
				i=i+2;
			}else{
				i++;
			}		
		}			
		return str.toString();	   	
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值