[剑指offer][JAVA]第二题

【问题描述】

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

【解答思路】

  1. 找到空格
  2. 替换空格
    2.1 新建字符串,找到空格就替换,非空格添加原字符
    2.2 在原来的基础上移动位置,从后往前
public class Solution {
  public String replaceSpace(StringBuffer str) {
      StringBuffer buf = new StringBuffer();
      if(str==null)
          return str.toString();
  	for(int i=0;i < str.length();i++) {
      if(str.charAt(i)!=' '){
          buf.append(str.charAt(i));
      } 
      else
      {
          buf.append("%20");
      }
      }
      return buf.toString();//牛客网一定要讲StringBuffer类型转化为String类型才能通过 
  } 
}

public class Solution {
    public String replaceSpace(StringBuffer str) {
        int spacenum = 0;//spacenum为计算空格数
        for(int i=0;i<str.length();i++){
            if(str.charAt(i)==' ')
                spacenum++;
        }
        int indexold = str.length()-1; //indexold为为替换前的str下标
        int newlength = str.length() + spacenum*2;//计算空格转换成%20之后的str长度
        int indexnew = newlength-1;//indexold为为把空格替换为%20后的str下标
        str.setLength(newlength);//使str的长度扩大到转换成%20之后的长度,防止下标越界
        for(;indexold>=0 && indexold<newlength;--indexold){ 
                if(str.charAt(indexold) == ' '){  //
                str.setCharAt(indexnew--, '0');
                str.setCharAt(indexnew--, '2');
                str.setCharAt(indexnew--, '%');
                }else{
                    str.setCharAt(indexnew--, str.charAt(indexold));
                }
        }
        return str.toString();
    }
}

#####使用replaceAll函数

public class Solution {
    public String replaceSpace(StringBuffer str) {
        return str.toString().replaceAll("\\s", "%20");
    }
}

【总结】

1.遍历字符串
String str="CryptWinter";

// 方法一

for(int i=0;i < str.length();i++) {

   System.out.println(str.charAt(i)); 
}

//方法二

for(int i=0;i < str.length();i++) {

   System.out.println(str.substring(i,i+1)); 
   
}

//方法三

char[]  c = str.toCharArray();

for(int i=0;i < c.length;i++) {

  System.out.println(c[i]);
}

2.字符串Stringbuffer常用函数
  • 创建 StringBuffer sb = new StringBuffer ();
  • 转换字符串 toString()
  • 增加 append(String s)
  • 插入 insert (int offset, int i)
  • 指定索引 charAt(int index)
    StringBuffer 方法
3.String与StringBuffer与用StringBuilder 区别
  • String 少量数据 字符串常量,字符串长度不可变
  • StringBuffer 多线程操作大量数据 频繁对字符串内容进行修改
  • StringBuilder 单线程操作大量数据 效率比StringBuffer提高百分之十左右
    参考链接:Java String、StringBuffer 和 StringBuilder 的区别
发布了22 篇原创文章 · 获赞 0 · 访问量 431

猜你喜欢

转载自blog.csdn.net/dadongwudi/article/details/104932674
今日推荐