Skip to content

Instantly share code, notes, and snippets.

@adambouchard
Last active December 17, 2015 14:03
Show Gist options
  • Save adambouchard/745fb00cd3e3eee081b1 to your computer and use it in GitHub Desktop.
Save adambouchard/745fb00cd3e3eee081b1 to your computer and use it in GitHub Desktop.
##MY OLD THINKING APPROACH
defmodule MathHelpers do
def average(values) do
unless Enum.empty?(values), do: Enum.sum(values) / Enum.count(values)
end
end
##PATTERN MATCHING APPROACH
defmodule MathHelpers do
def average([]), do: nil
def average(values), do: Enum.sum(values) / Enum.count(values)
end
values = [5,5,5,6,6,6]
#values = []
IO.puts MathHelpers.average(values)
@adambouchard
Copy link
Author

@alanpeabody... this doesn't work yet, but is this on the right path

defmodule MathHelpers do
  def average(values), do: Enum.empty?(values)
  def average(values), do: Enum.sum(values) / Enum.count(values)
end

@alanpeabody
Copy link

Close!

  def average([]), do: 0
  def average(values), do: Enum.sum(values) / Enum.count(values)

@adambouchard
Copy link
Author

nice. thanks

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment