LeetCode-Java:6.Z字形变换

2024-04-12 14:12
文章标签 java leetcode 变换 字形

本文主要是介绍LeetCode-Java:6.Z字形变换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 题目
      • ① 找规律

题目

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

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

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

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

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

string convert(string s, int numRows);

示例 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"

① 找规律

2ms,超过98.63%

43.69MB,超过86.85%

这道题还是有点难度在,一开始想要设置一个二维数组,遍历整个字符串,按照变换的规则将字符串存入到二维数组当中,最后将二维数组按照从左向右顺序读取转换成字符串。

写了一半,感觉这个思路写起来太麻烦了,想走个捷径,就按照下图的方式把原‘s’、排列情况、输出情况都列出来,想要得到一个‘函数’,可以使得输入转变为输出。

题目已经给定了numRows,按照规律排列能够找到第一行元素彼此之间间隔多少,后几行输出则根据第一行的输出±i (i=1,2,3…)即可

但在这种情况下,仍旧存在一些特殊情况需要考虑,比如如果numRows<2,那无论如何排列都是原本的‘s’,按照代码的情况的话,容易造成数组越界,所以numRows<2,直接返回s。

在这里插入图片描述

问题:为什么要设置use[]数组?

**答:**use[]数组主要用于记录字符串当中哪些元素已经被使用过,防止元素重复使用。具体在例子当中可以看为‘P A Y R A’,假设第一行是"P A",第二行是“A R”,第三行应该是‘Y’,如果按照代码的逻辑,在‘p’下标基础上+2输出一次,在‘A’下标基础上-2输出一次,那么‘Y’会被输出两次,有了use[]数组就可以保证只输出一次。当然也有其他的方法,不设置use[]数组也可以防止多输出情况,能够节省一些空间,但实现更复杂,更不易懂,感觉没必要。

问题:为什么第二个for循环当中的for循环设置j<len+numRows?

**答:**主要是因为用例“ABCD”,numRows=3无法通过。第一个for循环是用来确定第一行的情况的,第二个for循环是根据第一行情况找到第一行元素左右两侧±i的位置进行保存。用例“ABCD”,第一行只有‘A’,第二行应当为‘B D’,假设j<len的话,则第二行只有‘B’,因为‘D’是根据s[4](该元素不存在)的左右两侧进行确定的,所以理论上j一定得比len多出一个(2*numRows-2)/2,里面的判断只需要看j±i是否会超过数组范围就可保证不会越界。

那为什么是j<len+numRows,而不是j<len+numRows-1?主要原因是加上-1也可以,就是运行速度略微慢了一点,所以呐,这里去掉了,影响不大~

class Solution {public String convert(String s, int numRows) {if (numRows<2) return s;//如果numRows=1,则s不需要变换直接返回StringBuilder str=new StringBuilder();//StringBuilder比String运算速度要快int len=s.length();int[] use=new int[len];//记录s的元素是否使用过//变换后的第一行for(int i=0;i<len;i=i+2*numRows-2){use[i]=1;str.append(s.charAt(i));}//变换后的2~numRows行for(int i=1;i<numRows;i++){for(int j=0;j<len+numRows;j=j+2*numRows-2){//为什么设置j<len+numRows看上面//先j-1,后j+1,符合s的从左到右顺序if(j-i>=0 && j-i<len && use[j-i]!=1){//保证数组不越界,并且没使用过就加入到struse[j-i]=1;str.append(s.charAt(j-i));}if(j+i<len && use[j+i]!=1){//保证数组不越界,并且没使用过就加入到struse[j+i]=1;str.append(s.charAt(j+i));}}}return str.toString();//转换成字符串返回}
}

这篇关于LeetCode-Java:6.Z字形变换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/897358

相关文章

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows