【劍指Offer第二題】替換空格

題目描述
請實現一個函數,將一個字符串中的每個空格替換成“%20”。例如,當字符串爲We Are Happy.則經過替換之後的字符串爲We%20Are%20Happy。

*注:設給定字符串長度爲n。語言:C++


解法1:正向遍歷,遇到空格即進行替換,並將其後的元素相應後移。

void replaceSpace(char *str,int length) {
        if(length <= 0)
            return;
        char rep[] = "%20";
        char *out;
        int cnt = 0;
        for(int i = 0; i < length; ++i)
        {
            if(str[i] == ' ')
            {
                for(int j = length+1; j > i; --j)
                    str[j] = str[j-2];
                length += 2;
                strncpy(str+i, rep, 3);
            }
        }
    }

時間複雜度:O(n^2),空間複雜度:O(1)


解法2:正向遍歷計算空格數,再反向遍歷進行空格替換。

void replaceSpace(char *str,int length) {
        if(length <= 0)
            return;
        int cnt = 0;
        for(int i = 0; i < length; ++i)
        {
            if(str[i] == ' ')
                cnt += 2;
        }
        for(int i = length - 1; i >= 0; --i)
        {
            if(str[i] != ' ')
                str[i + cnt] = str[i];
            else
            {
                cnt -= 2;
                str[i + cnt] = '%';
                str[i + cnt + 1] = '2';
                str[i + cnt + 2] = '0';
            }
        }
    }

時間複雜度:O(n),空間複雜度:O(1)

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章