剑指 offer第五题,替换空格

    xiaoxiao2022-07-14  155

    将一个字符串中的空格替换成 “ ”。思路:一个替换成三个字符后,字符串会变长,不能扫一遍空格就替换,会覆盖空格后的字符串。用两个指针,初始位置都放在末尾,先扫一遍字符串,遇到空格就在末尾加上两个空格位置。两个指针同时走,一个遇上空格,另一个就依次加上0,2,%,否则就继续走,同时把前一个遇到的字符赋给后一个的位置。 public String replaceSpace(StringBuffer str) { int p1=str.length()-1; for(int i=0;i<=p1;i++){ if(str.charAt(i)==' ') str.append(" "); } int p2=str.length()-1; while(p1>=0 && p2>p1){ char c = str.charAt(p1--); if(c==' '){ str.setCharAt(p2--,'0'); str.setCharAt(p2--,'2'); str.setCharAt(p2--,'%'); }else str.setCharAt(p2--,c); } return str.toString(); }

    问题:

    str.append后面没有分号;while判断写成了for;c = str.charAt(p1–)写成了c = charAt(p1),最后一个字符一定不是空,所以从p1–开始,str.charAt才对,别忘了是哪个字符串的字符;if判断c里面又少写了等号。
    最新回复(0)