剑指Offer第二题

题目:请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
解法一:
思路:首先将StringBuffer字符串转化成String类型,因为下面要用到toCharArray。而StringBuffer类型的字符串是不可以调用toCharArray的。这里注意:StringBuffer字符串的创建方式,必须要用类的形式,不可以直接用定义赋值的形式。
然后借用把旧数组的值从后到前赋值给新数组。(首先要计算好新数组的长度)。最后再把新数组转化成字符串形式(toString和copyValueOf都可以,但是后者输出更符合要求)。

public class Solution {
    public String replaceSpace(StringBuffer str) {
    	String str1=str.toString();
	char[]c1=str1.toCharArray();
	int oldLength=c1.length;
	int m=0;
	for(char c:c1) {
		if(c==' ')
		{
			m++;
		}
	}
	int newLength=oldLength+m*2;
	char[]c2=new char[newLength];
	for(int i=newLength-1,j=oldLength-1;i>=0;)
	{
		if(c1[j]!=' ') {
			c2[i--]=c1[j--];
		}
		else if(c1[j]==' ') {
			c2[i--]='0';
			c2[i--]='2';
			c2[i--]='%';
			j--;
		}
	}
	String str2=String.copyValueOf(c2);
	return str2;
    }
    public static void main (String[] args ) {
		Solution s1=new Solution(); 
		StringBuffer str=new StringBuffer("We Are Happy");
		String str3=s1.replaceSpace(str);
        System.out.println(str3);
		
	}
}

解法二:利用栈

public class Solution1 {
public String replaceSpace(StringBuffer str) {
	String str1=str.toString();
	char[] c1=str1.toCharArray();
	int oldLength=c1.length;
	int m=0;
	for(char c:c1) {
		if(c==' ')
		{
			m++;
		}
	}
	int newLength=oldLength+m*2;
	char[]c2=new char[newLength];
	Stack <Character>stack=new Stack<Character>();
	int i=0;
	int j=newLength-1;
	while(i<oldLength) {
		stack.push(str1.charAt(i));
		i++;
	}
	while(!stack.empty()) {
		if(stack.peek()!=' ') {
			c2[j--]=stack.pop();
		}
		else if(stack.peek()==' ') {
			c2[j--]='0';
			c2[j--]='2';
			c2[j--]='%';
			stack.pop();
		}
	}

	String str2=String.copyValueOf(c2);
	return str2;
    }
	public static void main (String[] args ) {
		Solution1 s1=new Solution1(); 
		StringBuffer str=new StringBuffer("We Are Happy  DER");
		String str3=s1.replaceSpace(str);
        System.out.println(str3);
		
	}
}

注意:
(1)栈的定义需要用泛型,否则取出栈值的时候要强制转换
(2)stack.pop()会取出栈顶元素,并且栈顶指针会下移
stack.peek()则不会取出栈顶元素,他只会返回栈顶元素,栈顶指针不会下移
注意else if语句里的stack.pop();类似于第一种解法同样位置的j–;
解法三,大神解法,就一行代码
利用replaceAll().replaceAll() 方法使用给定的参数 replacement 替换字符串所有匹配给定的正则表达式的子字符串。
语法:public String replaceAll(String regex, String newChar)
regex – 匹配此字符串的正则表达式。

newChar – 用来替换每个匹配项的字符串。

成功则返回替换的字符串,失败则返回原始字符串。

public class Solution1 {
public String replaceSpace(StringBuffer str) {
	return str.toString().replaceAll(" ", "%20");
    }
	public static void main (String[] args ) {
		Solution1 s1=new Solution1(); 
		StringBuffer str=new StringBuffer("We Are Happy  DER");
		String str3=s1.replaceSpace(str);
        System.out.println(str3);
		
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值