我需要在 sml 中创建一个字典,但我在使用插入函数时遇到了极大的困难。
type dict = string -> int option
例如,这里是空字典:
val empty : dict = fn key => NONE
这是我对插入函数的实现:
fun insert (key,value) d = fn d => fn key => value
但这是错误的类型,我需要的是插入:(string*int) -> dict -> dict。我搜索了从惰性函数到实现字典的所有内容。任何帮助或方向将不胜感激!
如果您仍然对我要实现的内容感到困惑,我起草了调用简单查找函数时应该得到的内容
fun lookup k d = d k
- val d = insert ("foo",2) (insert ("bar",3) empty);
val d = fn : string -> int option
- lookup2 "foo" d;
val it = SOME 2 : int option
- lookup2 "bar" d;
val it = SOME 3 : int option
- lookup2 "baz" d;
val it = NONE : int option