Sha256: 88858ac8262e4173c8e4995b4d274468c568fe5833eb2f17e8100a98daab6c3b

Contents?: true

Size: 1.17 KB

Versions: 63

Compression:

Stored size: 1.17 KB

Contents

defmodule Transpose do
  @doc """
  Given an input text, output it transposed.

  Rows become columns and columns become rows. See https://en.wikipedia.org/wiki/Transpose.

  If the input has rows of different lengths, this is to be solved as follows:
    * Pad to the left with spaces.
    * Don't pad to the right.

  ## Examples
  iex> Transpose.transpose("ABC\nDE")
  "AD\nBE\nC"

  iex> Transpose.transpose("AB\nDEF")
  "AD\nBE\n F"
  """

  @spec transpose(String.t) :: String.t
  def transpose(matrix) do
    rows = String.split(matrix, "\n")

    max_length = get_longest_row_length(rows)

    rows
    |> Enum.map(fn x -> get_padded_row(x, max_length) end)
    |> Enum.map(fn x -> String.to_charlist(x) end)
    |> List.zip
    |> Enum.map(fn x -> Tuple.to_list(x) end)
    |> Enum.map(fn x -> List.to_string(x) end)
    |> Enum.map(fn x -> String.replace(x, "*", " ") end)
    |> Enum.join("\n")
    |> String.trim_trailing
  end

  defp get_longest_row_length(rows) do
    rows
    |> Enum.map(fn row -> String.length(row) end)
    |> Enum.max
  end

  defp get_padded_row(row, max_length) do
    padding = String.duplicate("*", max_length - String.length(row))
    row <> padding
  end
end

Version data entries

63 entries across 63 versions & 1 rubygems

Version Path
trackler-2.2.1.109 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.108 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.107 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.106 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.105 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.104 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.103 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.102 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.101 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.100 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.99 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.98 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.97 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.96 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.95 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.94 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.93 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.92 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.91 tracks/elixir/exercises/transpose/example.exs
trackler-2.2.1.90 tracks/elixir/exercises/transpose/example.exs