02替换空格

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

//思路:先遍历字符串,统计字符串中空格的总数,然后计算出替换后的字符串的总长度。
//首先准备两个指针p1和p2,p1指向原始字符串的末尾,p2指向替换后字符串的末尾。
//然后将p1指向的内容拷贝给p2,遇到空格,则p1向前移动一个位置,在p2之前插入字符串" ",p2向前移动3个位置。

//求一个字符串的长度,使用strlen(char*),不包含末尾的\0,对于参数为char*,也可以使用
 1 class Solution 
 2 {
 3 public:
 4     void replaceSpace(char *str,int length) //一维指针充当数组时,必须已知数组的长度
 5     {
 6         if (str == NULL || length <= 0)
 7         {
 8             return ;
 9         }
10         int origLength = strlen(str)+1;//原始字符串的长度
11         int newLength = 0;
12         int blackCount = 0;
13         int i = 0;
14         while(str[i] != '\0')
15         {
16             if (str[i] == ' ')
17             {
18                 blackCount++;
19             }
20             i++;
21         }
22         newLength = origLength + blackCount*2;
//新字符串的长度= 原始字符串的长度 + 空格数的2倍 23 while(origLength >=0 && origLength < newLength) 24 { 25 if (str[origLength] == ' ')//当前一个指针遇到空格时,后面的指针要向前移动3位 26 { 27 str[newLength--] = '0'; 28 str[newLength--] = '2'; 29 str[newLength--] = '%'; 30 } 31 else//否则只是后面的长度遇到一位 32 { 33 str[newLength--] = str[origLength]; 34 } 35 origLength--; 36 } 37 return; 38 } 39 };

 

posted @ 2017-08-03 22:34  繁星的夜空2012  阅读(102)  评论(0编辑  收藏  举报