欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

leetcode中如何解決ZigZagConversion問(wèn)題

這篇文章將為大家詳細(xì)講解有關(guān)leetcode中如何解決ZigZag Conversion問(wèn)題,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供譙城網(wǎng)站建設(shè)、譙城做網(wǎng)站、譙城網(wǎng)站設(shè)計(jì)、譙城網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、譙城企業(yè)網(wǎng)站模板建站服務(wù),十多年譙城做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

ZigZag Conversion

The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like this: (you may want to display this pattern in a fixed font for better legibility)

P   A   H   N
A P L S I I G
Y   I   R

And then read line by line: "PAHNAPLSIIGYIR"

Write the code that will take a string and make this conversion given a number of rows:

string convert(string text, int nRows);

convert("PAYPALISHIRING", 3) should return "PAHNAPLSIIGYIR".

題意:

鋸齒形(Z字形)的變換。變換形式如下所示:

A)行數(shù)為兩行的情形:
0 2 4
1 3 6

B)行數(shù)為三行的情形:
0   4   8
1 3 5 7 9
2   6   10

C)行數(shù)為四行的情形:      
0     6      12
1   5 7   11 13
2 4   8 10   14
3     9      15

D)行數(shù)為七行的情形:
第一行:0             12                24
第二行:1          11 13             23 25
第三行:2       10    14          22    26
第四行:3     9       15       21       27
第五行:4   8         16    20          28
第六行:5 7           17 19             29
第七行:6             18                30

觀察上面情形可知:

1)第一行和最后一行兩個(gè)元素之間的距離是:(行數(shù) - 1)* 2

2)中間幾行中第一個(gè)元素與第二個(gè)元素和第二個(gè)元素與第三個(gè)元素間的距離和是:(行數(shù) - 1)* 2.

3)中間幾行中第一個(gè)元素和第二個(gè)元素間的距離與第幾行的關(guān)系:(行數(shù)-第幾行)* 2.

4)中間幾行中第二個(gè)元素和第三個(gè)元素間的距離與第幾行的關(guān)系:(第幾行 - 1) * 2.

故有g(shù)etIndex()函數(shù):

1)如果是每行的第一個(gè)元素,直接返回行數(shù)。

2)如果是第一行或者最后一行的除首元素外的下標(biāo)獲取:前一個(gè)元素的下標(biāo) + (行數(shù) - 1)* 2

3)中間幾行的偶數(shù)列的下標(biāo)獲?。呵耙辉氐南聵?biāo) + (行數(shù)-第幾行)* 2

4)中間幾行的奇數(shù)列的下標(biāo)獲?。ǔ自兀呵耙辉叵聵?biāo) + (第幾行 - 1) * 2

注:

    程序中行數(shù)由于是從零開始的的,所以程序中會(huì)有相差一的出入。

int
getIndex(int index, int cnt, int numRows, int flag)
{
    if ( flag == 0 )
    {
        return cnt;
    }
    else if ( cnt == 0 || cnt == numRows - 1 )
    {
        index = index + ( numRows - 1) * 2;
    }
    else if ( flag % 2 != 0 )
    {
        index = index + (numRows - 1 - cnt) * 2;
    }
    else if ( flag % 2 == 0 )
    {
        index = index + cnt * 2;
    }
    
    return index;
}

char* convert(char* s, int numRows) 
{
    if ( *s == '\0' || numRows == 1 )
    {
        return s;
    }
    
    int len = strlen(s);
    if ( len <= numRows )
    {
        return s;
    }
    
    int add = 0;
    char rest[len + 1];
    int cnt = 0;
    for ( cnt = 0; cnt < numRows; cnt++ )
    {
        int index = 0;
        int flag  = 0;
        index = getIndex(index, cnt, numRows, flag);
        while ( index < len )
        {
            rest[add] = *(s + index);
            add   += 1;
            flag  += 1;
            index = getIndex(index, cnt, numRows, flag);
        }
    }
    rest[len] = '\0';
    
    sprintf(s, "%s", rest);
    
    return s;
}

逐行讀取每個(gè)元素,存入rest結(jié)果集中。最后寫會(huì)s,防止出現(xiàn)局部數(shù)組返回。

關(guān)于“l(fā)eetcode中如何解決ZigZag Conversion問(wèn)題”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

網(wǎng)頁(yè)題目:leetcode中如何解決ZigZagConversion問(wèn)題
文章出自:http://aaarwkj.com/article42/iigjhc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、品牌網(wǎng)站制作全網(wǎng)營(yíng)銷推廣、面包屑導(dǎo)航、App開發(fā)定制開發(fā)

廣告

聲明:本網(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í)需注明來(lái)源: 創(chuàng)新互聯(lián)

營(yíng)銷型網(wǎng)站建設(shè)
日韩精品在线观看不卡| 啄木乌法国一区二区三区| 麻豆视频91免费观看| 亚洲一区二区三区精品在线| 日韩av中文一区二区| 亚洲欧洲成熟熟女妇专区乱| 国产成人精品视频午夜蜜蜂| 亚洲巨大黑人一区二区三区| 加勒比av免费在线播放| 欧亚日韩精品一区二区在线| 欧美一级特黄大片做受另类| 麻豆国产免费av在线 | 国产超码片内射在线| 欧美日韩中文字幕精品视频| 欧美性色黄大片人与善| 中文字幕成人乱码亚洲| 中文字幕人妻出轨一区二区| 日韩精品一区伦理视频| 日本色网一区二区三区四区| 韩国三级在线视频网站| 九九在线视频精品免费播放| 亚洲高清中文字幕专区| 开心激情欧美一区二区| 91人妻精品一区二区| 亚洲精品中文字幕一二三| 丰满人妻一区二区三区色| 成人黄色av免费在线观看| 国产午夜福利片新视觉| 高清不卡一区二区在线观看| 日韩一级黄色片在线播放| 国产精品视频一区二区三区网站| 国产有码视频一区二区三区| 日韩黄色一级片在线观看| 五月婷婷六月丁香综合激情| 久久精品中文字幕人妻| 国产免费很黄很色视频| 精品熟女少妇av免费久久野外| 亚洲久久精品中文字幕| 高质量的性生活在线观看| 日本黄色中文字幕在线观看| 欧美国产日韩二区一区在线|