Leetcode6. N字形变换
创始人
2024-05-26 13:04:30

一、题目描述:

将一个给定字符串 s 根据给定的行数 numRows ,以从上往下、从左到右进行 Z 字形排列。
比如输入字符串为 “PAYPALISHIRING” 行数为 3 时,排列如下:

之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:“PAHNAPLSIIGYIR”。

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

string convert(string s, int numRows);

  1. 示例 1:

    输入:s = “PAYPALISHIRING”, numRows = 3
    输出:“PAHNAPLSIIGYIR”

  2. 示例 2:

    输入:s = “PAYPALISHIRING”, numRows = 4
    输出:“PINALSIGYAHRPI”

  3. 示例 3:

    输入:s = “A”, numRows = 1
    输出:“A”

  • 提示:
    • 1 <= s.length <= 1000
    • s 由英文字母(小写和大写)、‘,’ 和 ‘.’ 组成
    • 1 <= numRows <= 1000

二、解决思路和代码

  1. 解决思路

    • 找规律:每一行中,当前的字母与下一个字母之间的间隔TTT: T=numsRows+max(0,numRows−2)T = numsRows+max(0, numRows-2)T=numsRows+max(0,numRows−2)

    • 对于字符串 s ,索引为 i 的字符在 z 字形中位于第 j 行

      j={i%T,i%Ti%T,T−i%T,​i%T

  2. 代码

    class Solution:def convert(self, s: str, numRows: int) -> str:## 借助字典记录每一行的字符resDict = {}for idx in range(numRows):resDict[idx] = ''## 周期遍历查找T = numRows + max(0, (numRows - 2))for idx,stri in enumerate(s):if idx%T < numRows:resDict[idx%T] += strielse:resDict[T-idx%T] += stri## 打印输出res = ''       for key in resDict.keys():res += resDict[key]return res
    

相关内容

热门资讯

伊朗高官称美军超过500人丧生 伊朗最高国家安全委员会秘书拉里贾尼3月4日在社交平台上发文说,已有超过500名美国军人死于美国和以色...
又有470余名中国公民安全撤离   新华社电 外交部发言人毛宁3月4日表示,自伊朗安全形势紧张以来,中方已多次向有关方面提出交涉,要...
宜君县把岗位送到家门口   本报讯 (通讯员 赵建华)为扎实做好春节后稳就业保民生工作,近日,宜君县正式启动2026年“春风...
中国工程机械领军企业亮相北美最...   新华社美国拉斯维加斯3月3日电 (记者 谭晶晶 黄恒)北美规模最大的工程机械行业展会——拉斯维加...
食品核查处置“1350”机制试... (来源:中国消费者报)  本报福州讯(记者张文章)近日,市场监管总局2026年创新试点项目——福建省...