0

我需要创建一个方法,该方法采用列表列表(如[ [2,3,] , [4,5] ])并返回类似[2,3,4,5]. 我可以计算出逻辑,但我不知道如何在 SML 中定义方法。我试过了,但它没有编译

    fun appendall(l:list list):list = ...
4

2 回答 2

3

看看 List 库中的 concat 函数。

Moscow ML version 2.01 (January 2004)
Enter `quit();' to quit.
- load "List";
> val it = () : unit
- List.concat [[1,2],[3,4],[5,6]];
> val it = [1, 2, 3, 4, 5, 6] : int list
- quit();

另一种解决方案是使用 List.foldr

val concat = List.foldr op@ [];

或者你可以把它写成一个递归函数

fun concat2 [] = []
  | concat2 (x::xs) = x @ concat2 xs

希望这对您有所帮助。

于 2012-09-09T10:27:35.120 回答
1

看起来你只是把你的类型弄错了。列表必须是某物的列表(例如int list)。如果内容的类型无关紧要,您可以使用类型变量'a而不是具体类型(因此在您的情况下是 an'a list和 an 'a list list)。

但是,您几乎从不需要 ML 中的类型声明。只需编写没有它们的函数,编译器将能够从您对它们执行的操作中推断出变量的类型。

于 2012-09-08T03:15:07.953 回答