leetcode-Z字形变换
一、题目
将一个给定字符串根据给定的行数,以从上往下、从左到右进行 Z 字形排列。
比如输入字符串为 “LEETCODEISHIRING” 行数为 4 时,排列如下:
L D R
E O E I I
E C I H N
T S G
之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:”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
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/zigzag-conversion
二、思路一
将字符对应的索引显示,以numRows=3为例,行优先打印出字符
0| 1 5 9 13
1| 2 4 6 8 10 12 14 16
2| 3 7 11 15
每一行右边的字符的索引值都是其左边的字符的索引值加上它下面剩余行数的两倍或上面行数的两倍(具体看两个字符所在的行)
因为两个字符目前在同一行,所以左边的字符是经过从上到下的,然后斜着从左到右到右边的字符,或者相反。例如:
4 == 2(左边的索引) + 2(两倍) * 1(4的下面有一行)
7 == 3(左边的索引) + 2(两倍) * 2(3的上面有两行)
三 、代码实现
1 | func convert1(s string, numRows int) string { |
四、思路二
对原字符串进行分块处理,找到每块中数字在Z形变化后的对应关系。
L D R
E O E I I
E C I H N
T S G
将上图分成块[L E E T C O] [D E I S H I] [R I N G],每块的数量等于行数的二倍减2。每块的头元素相距2*4-2=6个元素。
五、代码实现
1 | func convert2(s string, numRows int) string { |
- 本文标题:leetcode-Z字形变换
- 本文作者:beyondhxl
- 本文链接:https://www.beyondhxl.com/post/d2e4e456.html
- 版权声明:本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明出处!