将一个给定字符串 s 根据给定的行数 numRows ,以从上往下、从左到右进行 Z 字形排列。
比如输入字符串为 “PAYPALISHIRING” 行数为 3 时,排列如下:
1 2 3
| P A H N A P L S I I G Y I R
|
之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:”PAHNAPLSIIGYIR”。
示例 1:
1 2
| 输入:s = "PAYPALISHIRING", numRows = 3 输出:"PAHNAPLSIIGYIR"
|
示例 2:
1 2 3 4 5 6 7
| 输入:s = "PAYPALISHIRING", numRows = 4 输出:"PINALSIGYAHRPI" 解释: P I N A L S I G Y A H R P I
|
示例 3:
1 2
| 输入:s = "A", numRows = 1 输出:"A"
|
实现方法:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
|
var convert = function (s, numRows) { if (numRows === 1) { return s; } let len = s.length; let a = 2 * numRows - 2 || 1; let group = Math.ceil(len / a);
let result = ""; for (let j = 0; j < numRows; j++) { for (let i = 0; i < group; i++) { let args = s.slice(i * a, (i + 1) * a); result += args[j] || ""; if (j !== 0 && j !== numRows - 1) { if (args.length > numRows && args[a - j]) { result += args[a - j]; } } } } return result; };
|