Leetcode 6. 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字形排列后再讀出的字符串。
可以依次得到各個行的字符串再拼接,比較簡單。
我是直接計算的字符串的每位是怎么映射到結(jié)果字符串的。都可以。
下面的C代碼,已通過。

char* convert(char* s, int numRows) {
    int length=0,i=0,k=0,ansk=0;
    while(s[length]!='\0')length++;
    if(numRows==1||numRows>=length)return s;
    char * ans=(char *)malloc((length+1)*sizeof(char));
    for(i=0;i<numRows;i++)
    {
        k=i;
        if(i==0||i==numRows-1)
        {
            while(length>k&&length>ansk)
            {
                ans[ansk]=s[k];k+=2*(numRows-1);ansk++;
            }
        }
        else
        {
            while(length>k&&length>ansk)
            {
                ans[ansk]=s[k];ansk++;
                k+=2*(numRows-i-1);
                if(k>=length||ansk>=length)break;
                ans[ansk]=s[k];ansk++;
                k+=2*(i);
            }
        }
       // printf("%s\n",ans);
    }
    ans[length]='\0';
    return ans;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容