Python面试宝典第17题:Z字形变换

题目

        将一个给定字符串 s 根据给定的行数numRows ,以从上往下、从左到右进行Z字形排列。比如:输入字符串为"PAYPALISHIRING",行数为3时,排列如下。最后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:"PAHNAPLSIIGYIR"。

P   A   H   N
A P L S I I G
Y   I   R

        示例 1:

输入:s = "PAYPALISHIRING", numRows = 3
输出:"PAHNAPLSIIGYIR"

        示例 2:

输入:s = "PAYPALISHIRING", numRows = 4
输出:"PINALSIGYAHRPI"
解释:
P     I    N
A   L S  I G
Y A   H R
P     I

        示例 3:

输入:s = "A", numRows = 1
输出:"A"

模拟生成法

        模拟生成法通过直接模拟Z字形路径的构建过程来求解,其基本思路为:创建一个二维数组来存储每行的字符,根据Z字形的移动规律填充字符。对于每一列,从上到下再从下到上交替填充字符,直到所有字符都被放置。最后,将二维数组的内容依次连接成一个字符串。使用模拟生成法求解本题的主要步骤如下。

        1、初始化。创建一个二维列表,大小为numRows行,用于存储Z字形排列的每个字符。同时,初始化行索引 row为0,方向变量goingDown为True表示当前正向下移动,False表示向上移动。

        2、遍历字符串。对于输入字符串 s 中的每个字符,根据当前的行索引row将字符放入二维列表的对应位置。

        3、更新行索引和方向。根据当前的移动方向更新行索引,如果到达第一行或最后一行,则改变移动方向。

        4、构造结果字符串。最后,遍历二维列表,将所有字符按顺序连接成一个字符串并返回。

        根据上面的算法步骤,我们可以得出下面的示例代码。

def zigzag_conversion_by_simulation(s: str, numRows: int) -> str:if numRows == 1 or numRows >= len(s):# 特殊情况处理:只有一行,或行数大于等于字符串长度时,直接返回原字符串return s# 初始化二维列表rows = [''] * numRowsrow = 0goingDown = Truefor char in s:# 在当前行添加字符rows[row] += charif goingDown:# 增加行索引row += 1# 到达最后一行,准备向上if row == numRows - 1:goingDown = Falseelse:# 减少行索引row -= 1# 回到第一行,准备向下if row == 0:goingDown = Truereturn ''.join(rows)print(zigzag_conversion_by_simulation('PAYPALISHIRING', 3))
print(zigzag_conversion_by_simulation('PAYPALISHIRING', 4))
print(zigzag_conversion_by_simulation('A', 1))

一次遍历法

        通过观察Z字形排列的规律,可以发现字符串中的字符实际上是以一定的周期性“跳跃”到下一行或上一行。我们可以直接通过计算确定每个字符应该落在哪一行,而不需要实际创建二维数组。使用一次遍历法求解本题的主要步骤如下。

        1、计算周期。首先,识别Z字形排列的周期性。对于每一组完整的“向下-向上”往返,涉及2*numRows - 2个字符。另外,还需考虑边界情况,即当行数为1或字符串长度不足以形成完整周期的场景。

        2、遍历并直接构建结果。通过计算当前字符在Z字形中的实际行位置,直接在结果字符串中构建输出。利用数学公式确定字符应落在哪一行,依据当前字符索引和Z字形的行数动态调整。

def zigzag_conversion_by_traversal(s: str, numRows: int) -> str:if numRows == 1 or numRows >= len(s):# 特殊情况处理:只有一行,或行数大于等于字符串长度时,直接返回原字符串return sresult = [''] * numRowsn = len(s)# 完整周期字符数cycle = 2 * numRows - 2for i in range(n):# 计算当前字符在Z字形中的行位置,在每个周期内,字符在前numRows-1行是递增,之后是递减row_index = i % cycle if i % cycle < numRows else cycle - i % cycle# 将字符添加到对应行result[row_index] += s[i]# 将结果列表中的字符串合并为一个字符串return ''.join(result)print(zigzag_conversion_by_traversal('PAYPALISHIRING', 3))
print(zigzag_conversion_by_traversal('PAYPALISHIRING', 4))
print(zigzag_conversion_by_traversal('A', 1))

总结

        模拟生成法的时间复杂度为O(n),其中n是输入字符串的长度。空间复杂度为O(numRows * m),其中m是字符串s中最长行的字符数。最坏情况下,如果numRows较大且字符串分布均匀,可能需要较大的空间来存储二维数组。模拟生成法直接反映了Z字形的实际构建过程,逻辑清晰,实现直观,易于理解和编码。缺点在于空间效率较低,当numRows很大时,可能会占用较多的空间。

        一次遍历法的时间复杂度也为O(n),空间复杂度为O(numRows),只需一个大小为numRows的列表来暂存每行的字符。相比模拟法,空间需求更低,特别是当字符串很长而numRows较小时。缺点在于实现相对抽象,理解其背后的数学逻辑可能需要更多的思考。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/874450.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

unity 实现图片的放大与缩小(根据鼠标位置拉伸放缩)

1创建UnityHelper.cs using UnityEngine.Events; using UnityEngine.EventSystems;public class UnityHelper {/// <summary>/// 简化向EventTrigger组件添加事件的操作。/// </summary>/// <param name"_eventTrigger">要添加事件监听的UI元素上…

DevExpress中文教程 - 如何在.NET MAUI应用中实现Material Design 3?

DevExpress .NET MAUI多平台应用UI组件库提供了用于Android和iOS移动开发的高性能UI组件&#xff0c;该组件库包括数据网格、图表、调度程序、数据编辑器、CollectionView和选项卡组件等。 获取DevExpress v24.1正式版下载 Material Design是一个由Google开发的跨平台指南系统…

HydraRPC: RPC in the CXL Era——论文阅读

ATC 2024 Paper CXL论文阅读笔记整理 问题 远程过程调用&#xff08;RPC&#xff09;是分布式系统中的一项基本技术&#xff0c;它允许函数在远程服务器上通过本地调用执行来促进网络通信&#xff0c;隐藏底层通信过程的复杂性简化了客户端/服务器交互[15]。RPC已成为数据中心…

【Hot100】LeetCode—279. 完全平方数

目录 题目1- 思路2- 实现⭐完全平方数——题解思路 3- ACM 实现 题目 原题连接&#xff1a;279. 完全平方数 1- 思路 思路 动规五部曲 2- 实现 ⭐完全平方数——题解思路 class Solution {public int numSquares(int n) {// 1. 定义 dpint[] dp new int[n1];//2. 递推公式…

论文学习记录之一种具有边缘增强特点的医学图像分割网络

标题&#xff1a;一种具有边缘增强特点的医学图像分割网络 期刊&#xff1a;电子与信息学报-&#xff08;2022年5月出刊&#xff09; 摘要&#xff1a;针对传统医学图像分割网络存在边缘分割不清晰、缺失值大等问题&#xff0c;该文提出一种具有边缘增强特点的医学图像分割网…

社交圈子小程序搭建-源码部署-服务公司

消息通知:当有新的消息、评论或回复时&#xff0c;用户需要收到系统的推送通知&#xff0c;以便及时查看和回复 活动发布与参加:用户可以在社交圈子中发布各种类型的活动&#xff0c;如聚餐、旅游、运动等。其他用户可以参加这些活动&#xff0c;并与组织者进行交流和沟通 社交…

C#初级——输出语句和转义字符

输出语句 在C#中&#xff0c;C#的输出语句是通过Console类进行输出&#xff0c;该类是一个在控制台下的一个标准输入流、输出流和错误流。使用该类下的Write()函数&#xff0c;即可打印要输出的内容。 Console.Write("Hello World!"); //在控制台应用中打印Hell…

通过QT进行服务器和客户端之间的网络通信

客户端 client.pro #------------------------------------------------- # # Project created by QtCreator 2024-07-02T14:11:20 # #-------------------------------------------------QT core gui network #网络通信greaterThan(QT_MAJOR_VERSION, 4): QT widg…

Docker安装nacos(详细教程)

Nacos 是一个开源的动态服务发现、配置管理和服务管理平台&#xff0c;广泛用于微服务架构中。在本文章中&#xff0c;博主将详细介绍如何使用 Docker 来安装 Nacos&#xff0c;以便快速启动并运行这个强大的服务管理工具。 前置条件 在开始安装 Nacos 之前&#xff0c;请确保…

pytorch 笔记:torch.optim.Adam

torch.optim.Adam 是一个实现 Adam 优化算法的类。Adam 是一个常用的梯度下降优化方法&#xff0c;特别适合处理大规模数据集和参数的深度学习模型 torch.optim.Adam(params, lr0.001, betas(0.9, 0.999), eps1e-08, weight_decay0, amsgradFalse, *, foreachNone, maximizeFa…

I2C总线二级外设驱动开发(函数和代码详解)

I2C总线二级外设驱动开发是一个涉及多个步骤和函数调用的过程&#xff0c;主要目的是使得挂接在I2C总线上的外设能够正常工作。 一、I2C总线二级外设驱动开发概述 I2C总线是一种广泛使用的串行通信总线&#xff0c;用于连接微控制器及其外围设备。在Linux内核中&#xff0c;I2…

实验四 FPGA 使用Verilog HDL设计电机运动控制程序

实验目的 1.掌握使用GPIO控制直流电机的原理。 2.掌握使用Verilog HDL设计电机运动控制程序的方法。 实验要求 采用Verilog HDL语言设计直流电机运动控制程序&#xff0c;实现直流电机的运动控制&#xff0c;并通过数码管显示当前输出的PWM波的占空比。通过按键或拔位开关可…

ArcGIS Pro不能编辑ArcGIS10.X的注记的解决办法

​ 点击下方全系列课程学习 点击学习—>ArcGIS全系列实战视频教程——9个单一课程组合系列直播回放 点击学习——>遥感影像综合处理4大遥感软件ArcGISENVIErdaseCognition 一、问题 我们利用ArcGIS Pro编辑ArcGIS10.X系列软件生成的注记要素类的时候&#xff0c;会提示不…

Apache POI-Excel入门与实战

目录 一、了解Apache POI 1.1 什么是Apache POI 1.2 为什么要使用ApaChe POI 1.3 Apache POI应用场景 1.4 Apache POI 依赖 二、Apache POI-Excel 入门案例 2.1 写入Excel文件 2.2 读取文件 四、Apache POI实战 4.1 创建一个获取天气的API 4.2高德天气请求API与响应…

怎样使用 Juicer tools 的 dump 命令将.hic文件转换为交互矩阵matrix计数文件 (Windows)

创作日志&#xff1a; 万恶的生信…一个scHiC数据集没有提供处理好的计数文件&#xff0c;需要从.hic转换。Github一个个好长的文档看了好久才定位到 juicer tools 的dump命令&#xff0c;使用起来比想象中简单。 一、下载Juicer tools 注意&#xff1a;使用Juicer tools的前提…

邮件安全篇:邮件反垃圾系统运作机制简介

1. 什么是邮件反垃圾系统&#xff1f; 邮件反垃圾系统是一种专门设计用于检测、过滤和阻止垃圾邮件的技术解决方案。用于保护用户的邮箱免受未经请求的商业广告、诈骗信息、恶意软件、钓鱼攻击和其他非用户意愿接收的电子邮件的侵扰。 反垃圾系统的常见部署形式 2. 邮件反垃圾…

day6 io线程

获取终端输入的字符

深入探究 Golang 反射:功能与原理及应用

Go 出于通用性的考量&#xff0c;提供了反射这一功能。借助反射功能&#xff0c;我们可以实现通用性更强的函数&#xff0c;传入任意的参数&#xff0c;在函数内通过反射动态调用参数对象的方法并访问它的属性。举例来说&#xff0c;下面的bridge接口为了支持灵活调用任意函数&…

python一维表转二维表

一维表转二维表 import pandas as pd # 读取数据 product_df pd.read_csv(rD:\excelFile\practice\物品属性值一维表.csv,encodingutf-8) # print(product_df)# 将一维表转变二维 s pd.Series(list(product_df[属性值]),index[product_df[物品编号],product_df[属性名]]) …

GMSSL2.x编译鸿蒙静态库和动态库及使用

一、编译环境准备 1.1 开发工具 DevEco-Studio下载。 1.2 SDK下载 ​ 下载编译第三方库的SDK有两种方式&#xff0c;第一种方式从官方渠道根据电脑系统选择对应的SDK版本&#xff0c;第二种方式通过DevEco-Studio下载SDK。本文只介绍通过DevEco-Studio下载SDK的方式。 安装…