Q6 - medium - Z 字形变换

将一个给定字符串根据给定的行数,以从上往下、从左到右进行 Z 字形排列。

比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下:

L C I R
E T O E S I I G
E D H N
之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:"LCIRETOESIIGEDHN"。

请你实现这个将字符串进行指定行数变换的函数:

string convert(string s, int numRows);
示例 1:

输入: s = "LEETCODEISHIRING", numRows = 3
输出: "LCIRETOESIIGEDHN"
示例 2:

输入: s = "LEETCODEISHIRING", numRows = 4
输出: "LDREOEIIECIHNTSG"
解释:

L D R
E O E I I
E C I H N
T S G

题目真的是难以理解,其实理解了非常好做的。意思就是,先从上向下,再从下向上,跟Z字没什么关系,更贴切的应该说是一个上下翻了个个儿的N。

class Solution:
    def convert(self, s, numRows):
        """
        :type s: str
        :type numRows: int
        :rtype: str
        """
        res = ["" for _ in range(numRows)]
        going_down = True
        i = 0
        for _s in s:
            res[i] += _s
            if going_down:
                i += 1
                if i >= numRows:
                    i -= 2
                    going_down = False
            else:
                i -= 1
                if i < 0:
                    i += 2
                    going_down = True
        return "".join([x for x in res])
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 8,755评论 0 2
  • 一、Python简介和环境搭建以及pip的安装 4课时实验课主要内容 【Python简介】: Python 是一个...
    _小老虎_阅读 11,132评论 0 10
  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 9,947评论 0 5
  • 清明节放假的第三天,哈尔滨雾霾的天空,终于有些放亮了,我们全家便趁机一起来到了群力城市湿地公园游玩。 ...
    没有最二阅读 4,400评论 0 0
  • 又或许我们根本不够清淡,想在春天的书页里留下一笔墨绿,却被清风错翻了页码。 五岁前,在杭州陆官巷;五岁时,随父...
    莉莉安lilianan阅读 2,795评论 0 0