概述
【LeetCode】打卡–Python3算法6. 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
结果
执行用时 : 84 ms, 在ZigZag Conversion的Python3提交中击败了99.96% 的用户
内存消耗 : 13.4 MB, 在ZigZag Conversion的Python3提交中击败了8.23% 的用户
Python解答
分析:结果是按照行数n来排序,首先创建一个长度为n的列表,然后按照顺序在列表的第i个位置添加数据,最后拼接起来。
class Solution:
def convert(self, s: str, numRows: int) -> str:
listA = numRows*['']
a = 0
if(numRows==1):
return s
for i in range(len(s)):
listA[a] = listA[a] + s[i]
if((i//(numRows-1))%2==0):
a = a + 1
else:
a = a - 1
return ''.join(listA)
我们下次再见,如果还有下次的话!!!
欢迎关注微信公众号:516数据工作室
最后
以上就是无心画笔为你收集整理的【LeetCode】打卡--Python3算法6. Z 字形变换的全部内容,希望文章能够帮你解决【LeetCode】打卡--Python3算法6. Z 字形变换所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复