題目來源:https://leetcode.cn/problems/zigzag-conversion/description/
創(chuàng)新互聯(lián)公司是一家專注于成都網(wǎng)站設(shè)計、成都網(wǎng)站制作與策劃設(shè)計,泗陽網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)公司做網(wǎng)站,專注于網(wǎng)站建設(shè)10余年,網(wǎng)設(shè)計領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:泗陽等地區(qū)。泗陽做網(wǎng)站價格咨詢:18982081108C++題解:按行讀取,每數(shù)列的索引間隔是相同的,除了首行和尾行,還有一個中間元素,循環(huán)用數(shù)組的長度來控制。
class Solution {
public:
string convert(string s, int numRows) {
int len = s.size();
int jj = 0, jjj = 0; //jj為索引,jjj為第幾行
int aa = 2*numRows - 2, mm = 0; //aa是列的間隔,為固定值;mm為中間行的中間列索引間隔
string daan = "";
if((numRows >= len)or(numRows == 1)) return s; //特殊情況
daan = daan + s[0]; //首個元素
for(int ii = 0; ii< len; ii++){ //用len控制循環(huán)次數(shù)
if((jjj == 0)or(jjj == numRows-1)){ //第一行和最后一行,每次加一個
if(jj + aa< len){
jj = jj + aa;
daan = daan + s[jj];
}
else { // 跳出范圍換行
jjj++;
jj = jjj;
if(jjj != numRows) daan = daan + s[jj];
}
}
else{ //中間行,每次要加兩個
mm = aa - 2*jjj;
if(jj + mm< len) { // 判斷斜線的元素
daan = daan + s[jj+mm];
if(jj + aa< len){ // 判斷下一列,aa是固定的間隔
jj = jj + aa;
daan = daan + s[jj];
ii++; //一次加兩個元素,新字符索引也要增長
}
else { // 跳出范圍換行,再加上新行的第一個元素
jjj++;
jj = jjj;
daan = daan + s[jj];
ii++; //一次加兩個元素,新字符索引也要增長
}
}
else { // 跳出范圍換行,再加上新行的第一個元素
jjj++;
jj = jjj;
daan = daan + s[jj];
}
}
}
return daan;
}
};
你是否還在尋找穩(wěn)定的海外服務(wù)器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機(jī)房具備T級流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確流量調(diào)度確保服務(wù)器高可用性,企業(yè)級服務(wù)器適合批量采購,新人活動首月15元起,快前往官網(wǎng)查看詳情吧
網(wǎng)站題目:力扣6.Z字形變換-創(chuàng)新互聯(lián)
當(dāng)前網(wǎng)址:http://chinadenli.net/article20/dhjjjo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、搜索引擎優(yōu)化、定制開發(fā)、域名注冊、建站公司、微信公眾號
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容