這篇文章主要介紹“C++怎么實(shí)現(xiàn)字型轉(zhuǎn)換字符串”,在日常操作中,相信很多人在C++怎么實(shí)現(xiàn)字型轉(zhuǎn)換字符串問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對(duì)大家解答”C++怎么實(shí)現(xiàn)字型轉(zhuǎn)換字符串”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!
成都創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都做網(wǎng)站、網(wǎng)站建設(shè)、外貿(mào)營銷網(wǎng)站建設(shè)、保定網(wǎng)絡(luò)推廣、微信小程序、保定網(wǎng)絡(luò)營銷、保定企業(yè)策劃、保定品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);成都創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供保定建站搭建服務(wù),24小時(shí)服務(wù)熱線:18982081108,官方網(wǎng)址:muchs.cn
Example 1:
Input: s = "PAYPALISHIRING", numRows = 3
Output: "PAHNAPLSIIGYIR"
Example 2:
Input: s = "PAYPALISHIRING", numRows = 4
Output: "PINALSIGYAHRPI"
Explanation:P I N
A L S I G
Y A H R
P I
這道題剛開始看了半天沒看懂是咋樣變換的,上網(wǎng)查了些資料,終于搞懂了,就是要把字符串?dāng)[成一個(gè)之字型的,比如有一個(gè)字符串 "0123456789ABCDEF",轉(zhuǎn)為 zigzag 如下所示:
當(dāng) n = 2 時(shí):
0 2 4 6 8 A C E
1 3 5 7 9 B D F
當(dāng) n = 3 時(shí):
0 4 8 C
1 3 5 7 9 B D F
2 6 A E
當(dāng) n = 4 時(shí):
0 6 C
1 5 7 B D
2 4 8 A E
3 9 F
可以發(fā)現(xiàn),除了第一行和最后一行沒有中間形成之字型的數(shù)字外,其他都有,而首位兩行中相鄰兩個(gè)元素的 index 之差跟行數(shù)是相關(guān)的,為 2*nRows - 2, 根據(jù)這個(gè)特點(diǎn),可以按順序找到所有的黑色元素在元字符串的位置,將他們按順序加到新字符串里面。對(duì)于紅色元素出現(xiàn)的位置(Github 上可能無法正常顯示顏色,請(qǐng)參見博客園上的帖子)也是有規(guī)律的,每個(gè)紅色元素的位置為 j + 2 x numRows-2 - 2 x i, 其中,j為前一個(gè)黑色元素的 index,i為當(dāng)前行數(shù)。 比如當(dāng) n = 4 中的那個(gè)紅色5,它的位置為 1 + 2 x 4-2 - 2 x 1 = 5,為原字符串的正確位置。知道了所有黑色元素和紅色元素位置的正確算法,就可以一次性的把它們按順序都加到新的字符串里面。代碼如下:
解法一:
class Solution { public: string convert(string s, int numRows) { if (numRows <= 1) return s; string res; int size = 2 * numRows - 2, n = s.size(); for (int i = 0; i < numRows; ++i) { for (int j = i; j < n; j += size) { res += s[j]; int pos = j + size - 2 * i; if (i != 0 && i != numRows - 1 && pos < n) res += s[pos]; } } return res; } };
若上面解法中的規(guī)律不是很好想的話,我們也可以用下面這種更直接的方法來做,建立一個(gè)大小為 numRows 的字符串?dāng)?shù)組,為的就是把之字形的數(shù)組整個(gè)存進(jìn)去,然后再把每一行的字符拼接起來,就是想要的結(jié)果了。順序就是按列進(jìn)行遍歷,首先前 numRows 個(gè)字符就是按順序存在每行的第一個(gè)位置,然后就是 ‘之" 字形的連接位置了,可以發(fā)現(xiàn)其實(shí)都是在行數(shù)區(qū)間 [1, numRows-2] 內(nèi),只要按順序去取字符就可以了,最后把每行都拼接起來即為所求,參見代碼如下:
解法二:
class Solution { public: string convert(string s, int numRows) { if (numRows <= 1) return s; string res; int i = 0, n = s.size(); vector<string> vec(numRows); while (i < n) { for (int pos = 0; pos < numRows && i < n; ++pos) { vec[pos] += s[i++]; } for (int pos = numRows - 2; pos >= 1 && i < n; --pos) { vec[pos] += s[i++]; } } for (auto &a : vec) res += a; return res; } };
到此,關(guān)于“C++怎么實(shí)現(xiàn)字型轉(zhuǎn)換字符串”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!
網(wǎng)頁名稱:C++怎么實(shí)現(xiàn)字型轉(zhuǎn)換字符串
文章起源:http://muchs.cn/article0/gepjio.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、網(wǎng)站制作、網(wǎng)站導(dǎo)航、面包屑導(dǎo)航、用戶體驗(yàn)、網(wǎng)站收錄
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)