Class Solution
- java.lang.Object
-
- g2001_2100.s2075_decode_the_slanted_ciphertext.Solution
-
public class Solution extends Object
2075 - Decode the Slanted Ciphertext.Medium
A string
originalTextis encoded using a slanted transposition cipher to a stringencodedTextwith the help of a matrix having a fixed number of rowsrows.originalTextis placed first in a top-left to bottom-right manner.
The blue cells are filled first, followed by the red cells, then the yellow cells, and so on, until we reach the end of
originalText. The arrow indicates the order in which the cells are filled. All empty cells are filled with' '. The number of columns is chosen such that the rightmost column will not be empty after filling inoriginalText.encodedTextis then formed by appending all characters of the matrix in a row-wise fashion.
The characters in the blue cells are appended first to
encodedText, then the red cells, and so on, and finally the yellow cells. The arrow indicates the order in which the cells are accessed.For example, if
originalText = "cipher"androws = 3, then we encode it in the following manner:
The blue arrows depict how
originalTextis placed in the matrix, and the red arrows denote the order in whichencodedTextis formed. In the above example,encodedText = "ch ie pr".Given the encoded string
encodedTextand number of rowsrows, return the original stringoriginalText.Note:
originalTextdoes not have any trailing spaces' '. The test cases are generated such that there is only one possibleoriginalText.Example 1:
Input: encodedText = “ch ie pr”, rows = 3
Output: “cipher”
Explanation: This is the same example described in the problem description.
Example 2:

Input: encodedText = “iveo eed l te olc”, rows = 4
Output: “i love leetcode”
Explanation: The figure above denotes the matrix that was used to encode originalText.
The blue arrows show how we can find originalText from encodedText.
Example 3:

Input: encodedText = “coding”, rows = 1
Output: “coding”
Explanation: Since there is only 1 row, both originalText and encodedText are the same.
Constraints:
0 <= encodedText.length <= 106encodedTextconsists of lowercase English letters and' 'only.encodedTextis a valid encoding of someoriginalTextthat does not have trailing spaces.1 <= rows <= 1000- The testcases are generated such that there is only one possible
originalText.
-
-
Constructor Summary
Constructors Constructor Description Solution()
-