日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

替换字符串中的空格

發布時間:2024/7/23 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 替换字符串中的空格 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

劍指offer面試題

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

看到題目后的思路

看到這個題目后,我們首相應該想到的是:原來的一個空格字符,經過替換后就成了三個字符,因此字符會變長,那么很有可能會覆蓋原來的字符。如果是在一個新創建的字符串上做替換,就可以有足夠的空間,顯然題目上沒有明顯的提出,那就應該在原來的字符串上做替換

偽代碼實現

  • 求出該字符串的長度和字符串中含有的空格數
  • 求出替換后的字符串的總長度
  • 準備兩個指針pStr1,pStr2,pStr1指向原始字符串的末尾,pStr2指向替換后的字符串末尾
  • 向前移動pStr1和pStr2,逐個將pStr1指向的字符拷貝到Pr2指向的位置,知道遇到第一個空格為止
  • 遇到空格后,將pStr1向前移動一次,然后在pStr2之前插入“%20”,插入一個字符pStr2就要向前移動一次
  • 繼續向前移動pStr1和pStr2,逐個將pStr1指向的字符拷貝到pStr2指向的位置,遇到空格繼續做“5”操作,直到pStr2和pStr1相等,說明空格已經全部替換完畢
  • 思維圖


    (圖片來源《劍指offer》)

    c++代碼實現

    class Solution { public:void replaceSpace(char *str, int length) {if (str == NULL && length <= 0)return;//如果是空直接返回int factlength = 0;//實際字符數int spacenumber = 0;//字符串中空格的數量int i = 0;while (str[i] != '\0'){++factlength;if (str[i] == ' '){++spacenumber;}++i;}//擴展第二個字符串,//空格的數量*2是因為“%20”一共三個字符,需要在原來每個空格的位置再加上兩個字符的長度,才是第二個字符串的int newlength = factlength + spacenumber * 2;if (newlength > length){return;}//從后向前替換,這樣會減少替換的次數char *pStr1 = str + factlength;char *pStr2 = str + newlength;//如果pStr2 <= pStr1 了,說明剩下的pStr2和pStr1的字符串相同了,也就沒有“ ”了,就不用替換了while (pStr2 > pStr1 && pStr1 >= 0){if (*pStr1 == ' '){*pStr2-- = '0';*pStr2-- = '2';*pStr2-- = '%';}else{*pStr2-- = *pStr1;}--pStr1;}return;} };

    總結

    以上是生活随笔為你收集整理的替换字符串中的空格的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。