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字形排列后再读出的字符串。
可以依次得到各个行的字符串再拼接,比较简单。
我是直接计算的字符串的每位是怎么映射到结果字符串的。都可以。
下面的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;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容