Rail Fence Cipher

The rail fence cipher (also called a zigzag cipher) is a transposition cipher in which the message is split across a set of rails on a fence for encoding. The fence is populated with the message’s characters, starting at the top left and adding a character on each position, traversing them diagonally to the bottom. Upon reaching the last rail, the direction should then turn diagonal and upwards up to the very first rail in a zig-zag motion. Rinse and repeat until the message is fully disposed across the fence. The encoded message is the result of concatenating the text in each rail, from top to bottom.

From wikipedia, this is what the message WE ARE DISCOVERED. FLEE AT ONCE looks like on a 3-rail fence:

  1. W . . . E . . . C . . . R . . . L . . . T . . . E
  2. . E . R . D . S . O . E . E . F . E . A . O . C .
  3. . . A . . . I . . . V . . . D . . . E . . . N . .
  4. -------------------------------------------------
  5. WECRLTEERDSOEEFEAOCAIVDEN

The message can then be decoded by re-creating the encoded fence, with the same traversal pattern, except characters should only be added on one rail at a time. To illustrate that, a dash can be added on the rails that are not supposed to be populated yet. This is what the fence would look like after populating the first rail, the dashes represent positions that were visited but not populated.

  1. W . . . E . . . C . . . R . . . L . . . T . . . E
  2. . - . - . - . - . - . - . - . - . - . - . - . - .
  3. . . - . . . - . . . - . . . - . . . - . . . - . .

It’s time to start populating the next rail once the number of visited fence positions is equal to the number of characters in the message.

References