Elixir - 具有递归的列表值的总和

时间:2014-07-14 01:21:24

标签: erlang elixir

只是尝试对列表值进行简单的总和。

defmodule Mth do 

    def sum_list([]) do 
        0
    end

    def sum_list([H|T]) do
        H + sum_list(T)
    end

end

IO.puts Mth.sum_list([1, 2, 300]) 

但是我收到了这个错误:

**(FunctionClauseError) no function clause matching in Mth.sum_list/1
    pokus.ex:3: Mth.sum_list([1, 2, 300])
    pokus.ex:14: (file)
    (elixir) src/elixir_lexical.erl:17: :elixir_lexical.run/2
    (elixir) lib/code.ex:316: Code.require_file/2**

5 个答案:

答案 0 :(得分:13)

您需要为变量和函数名称使用小写字母。以大写字母开头的标识符保留给模块:

defmodule Mth do 

  def sum_list([]) do 
    0
  end

  def sum_list([h|t]) do
    h + sum_list(t)
  end

end

iex> IO.puts Mth.sum_list([1, 2, 300])
303
:ok

答案 1 :(得分:7)

为了改进Chris的解决方案,如果你希望你的sum函数是尾递归的,你需要稍微修改它:

defmodule Mth do 
  def sum_list(list), do: do_sum_list(list, 0)

  defp do_sum_list([], acc),    do: acc
  defp do_sum_list([h|t], acc), do: do_sum_list(t, acc + h)
end

iex> Mth.sum_list([1, 2, 300])
303

答案 2 :(得分:3)

如果您打算使用Enum.reduce,您可以更简单:

defmodule Mth do
  def sum_list(list), do: Enum.reduce(list, 0, &(&1 + &2))
end

答案 3 :(得分:0)

为了完整起见,这也可行:

defmodule Mth do

  def sum_list(list), do: do_sum_list(list,0)

  defp do_sum_list(l,i_acc), do: Enum.reduce(l, i_acc, fn(x, accum) -> x + accum end)

end

我发布此信息仅供其他可能发现此问题及其答案的人参考。

答案 4 :(得分:-1)

尝试一下:

sum_list=[1,2,300]     
Enum.sum sum_list     
303