我是靠谱客的博主 无心画笔,最近开发中收集的这篇文章主要介绍【LeetCode】打卡--Python3算法6. Z 字形变换,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

【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数据工作室
516数据工作室

最后

以上就是无心画笔为你收集整理的【LeetCode】打卡--Python3算法6. Z 字形变换的全部内容,希望文章能够帮你解决【LeetCode】打卡--Python3算法6. Z 字形变换所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(63)

评论列表共有 0 条评论

立即
投稿
返回
顶部