我只是在编程,药剂和增强分裂。
我的代码如下-
defmodule MyEnum do
def split(l, n) do
def split_helper([], pre, _n), do: {pre, []}
def split_helper(l, pre, 0), do: {pre, l}
def split_helper([h|t], pre, n), do: split_helper(t, [h|pre], n-1)
split_helper(l, [], n)
end
end
我得到了错误-无法在函数/宏中调用def/2
这意味着我不能嵌套命名的函数。由于您不能编写递归匿名函数,而且也没有letrec,所以我想知道如何嵌套嵌套函数,其中嵌套函数是递归函数。这就是我在racket中构建代码的方式,因为我不需要在任何其他地方使用split_helper。
发布于 2019-08-23 14:35:25
函数不能嵌套在Elixir中。句号。
实现这一点的惯用方法是有一个名为do_split/3
的私有函数。
defmodule MyEnum do
def split(l, n), do: do_split(l, [], n)
defp do_split([], pre, _n), do: {pre, []}
defp do_split(l, pre, 0), do: {pre, l}
defp do_split([h|t], pre, n), do: do_split(t, [h|pre], n-1)
end
另一种解决问题的方法是简单地使用split/3
本身的几个子句。
defmodule MyEnum do
def split(l, acc \\ [], n) # default values
def split([], pre, _n), do: {pre, []}
def split(l, pre, 0), do: {pre, l}
def split([h|t], pre, n), do: split(t, [h|pre], n-1)
end
最不优雅但仍然有效的方法是创建匿名函数并传递给它。
defmodule MyEnum do
def split(l, n) do
split_helper = fn
[], pre, _, _ -> {pre, []}
l, pre, 0, _ -> {pre, l}
[h|t], pre, n, split_helper ->
split_helper.(t, [h|pre], n-1, split_helper)
end
split_helper.(l, [], n, split_helper)
end
end
发布于 2019-08-23 14:44:44
这也是值得研究的实现 of String.split_at/2
。
def split_at(string,pos) do do_split_at(string,0,pos,0) end defp do_split_at(string,acc,desired_pos,current_pos)当desired_pos > current_pos do case next_grapheme_size(string) do {count,rest} -> do_split_at(rest,acc + count,desired_pos,current_pos + 1) nil -> {acc,nil} end defp do_split_at(string,acc,desired_pos,( desired_pos)做{acc,string} end
https://stackoverflow.com/questions/57628302
复制相似问题