1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-01-25 17:50:26 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
leetcode-problemset/leetcode-cn/problem (Chinese)/解码斜向换位密码 [decode-the-slanted-ciphertext].html
2022-03-29 12:43:11 +08:00

69 lines
3.9 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<p>字符串 <code>originalText</code> 使用 <strong>斜向换位密码</strong> ,经由 <strong>行数固定</strong><code>rows</code> 的矩阵辅助,加密得到一个字符串 <code>encodedText</code></p>
<p><code>originalText</code> 先按从左上到右下的方式放置到矩阵中。</p>
<img alt="" src="https://assets.leetcode.com/uploads/2021/11/07/exa11.png" style="width: 300px; height: 185px;" />
<p>先填充蓝色单元格,接着是红色单元格,然后是黄色单元格,以此类推,直到到达 <code>originalText</code> 末尾。箭头指示顺序即为单元格填充顺序。所有空单元格用 <code>' '</code> 进行填充。矩阵的列数需满足:用 <code>originalText</code> 填充之后,最右侧列 <strong>不为空</strong></p>
<p>接着按行将字符附加到矩阵中,构造&nbsp;<code>encodedText</code></p>
<img alt="" src="https://assets.leetcode.com/uploads/2021/11/07/exa12.png" style="width: 300px; height: 200px;" />
<p>先把蓝色单元格中的字符附加到 <code>encodedText</code> 中,接着是红色单元格,最后是黄色单元格。箭头指示单元格访问顺序。</p>
<p>例如,如果 <code>originalText = "cipher"</code><code>rows = 3</code> ,那么我们可以按下述方法将其编码:</p>
<img alt="" src="https://assets.leetcode.com/uploads/2021/10/25/desc2.png" style="width: 281px; height: 211px;" />
<p>蓝色箭头标识 <code>originalText</code> 是如何放入矩阵中的,红色箭头标识形成 <code>encodedText</code> 的顺序。在上述例子中,<code>encodedText = "ch&nbsp; &nbsp;ie&nbsp; &nbsp;pr"</code></p>
<p>给你编码后的字符串 <code>encodedText</code> 和矩阵的行数 <code>rows</code> ,返回源字符串 <code>originalText</code></p>
<p><strong>注意:</strong><code>originalText</code> <strong></strong> 含任何尾随空格 <code>' '</code> 。生成的测试用例满足 <strong>仅存在一个</strong> 可能的 <code>originalText</code></p>
<p>&nbsp;</p>
<p><strong>示例 1</strong></p>
<pre>
<strong>输入:</strong>encodedText = "ch ie pr", rows = 3
<strong>输出:</strong>"cipher"
<strong>解释:</strong>此示例与问题描述中的例子相同。
</pre>
<p><strong>示例 2</strong></p>
<p><img alt="" src="https://assets.leetcode.com/uploads/2021/10/26/exam1.png" style="width: 250px; height: 168px;" /></p>
<pre>
<strong>输入:</strong>encodedText = "iveo eed l te olc", rows = 4
<strong>输出:</strong>"i love leetcode"
<strong>解释:</strong>上图标识用于编码 originalText 的矩阵。
蓝色箭头展示如何从 encodedText 找到 originalText 。
</pre>
<p><strong>示例 3</strong></p>
<p><img alt="" src="https://assets.leetcode.com/uploads/2021/10/26/eg2.png" style="width: 300px; height: 51px;" /></p>
<pre>
<strong>输入:</strong>encodedText = "coding", rows = 1
<strong>输出:</strong>"coding"
<strong>解释:</strong>由于只有 1 行,所以 originalText 和 encodedText 是相同的。
</pre>
<p><strong>示例 4</strong></p>
<img alt="" src="https://assets.leetcode.com/uploads/2021/10/26/exam3.png" style="width: 150px; height: 101px;" />
<pre>
<strong>输入:</strong>encodedText = " b ac", rows = 2
<strong>输出:</strong>" abc"
<strong>解释:</strong>originalText 不能含尾随空格,但它可能会有一个或者多个前置空格。
</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>0 &lt;= encodedText.length &lt;= 10<sup>6</sup></code></li>
<li><code>encodedText</code> 仅由小写英文字母和 <code>' '</code> 组成</li>
<li><code>encodedText</code> 是对某个 <strong>不含</strong> 尾随空格的 <code>originalText</code> 的一个有效编码</li>
<li><code>1 &lt;= rows &lt;= 1000</code></li>
<li>生成的测试用例满足 <strong>仅存在一个</strong> 可能的 <code>originalText</code></li>
</ul>