思路:

    从前往后:在原基础上进行替换(当然前提是空间足够),如果从前往后遇到空格就替换,必然会对原来的字符造成覆盖,不可以实现。


    因为把空格替换为”%20“,每次替换多2个字符,因此可以统计出字符串中空格的总个数,然后新数组大小为  “原数组大小 + 2*空格数 ”。从后往前处理:遇到非空格,直接搬到后面,遇到空格替换为”%20“. 直到待插入位置指针和原数组为指针重合位置。


代码如下:


#define _CRT_SECURE_NO_WARNINGS 1
#include<iostream>
using namespace std;

char* TransferString(char* str,int capacity)
{
    char* ret = str;
    if (str == NULL || capacity <= 0)
    {
        return NULL;
    }
    int i = 0;
    int originalLen = 0;
    int numberofblank = 0;
    while (str[i])
    {
        
        if (str[i] == ' ')
        {
            numberofblank++;
        }
        originalLen++;
        i++;
    }
    
    int newLen = originalLen + 2 * numberofblank;
    if (newLen >= capacity)
    {
        return NULL; 
    }
    
    while (newLen>originalLen && originalLen >=0)
    {
        if (str[originalLen] == ' ')
        {
            str[newLen--] = '0';
            str[newLen--] = '2';
            str[newLen--] = '%';
        }
        else
        {
            str[newLen] = str[originalLen];
            newLen--;
        }
        originalLen--;
        
    }
    return ret;
}


void Test()
{
    char arr[30] = "We are happy!";
    cout << TransferString(arr,30)<<endl;
}

int main()
{
    Test();
    system("pause");
    return 0;
}