小编lje*_*osn的帖子

Visual Studio代码的Ionide-fsharp

在我为Visual Studio Code安装Ionide之后,我该如何开始使用它(例如语法高亮,自动完成)?我需要更改哪些设置?

intellisense f# install visual-studio-code ionide

7
推荐指数
1
解决办法
1013
查看次数

F#中的递归序列

假设我想计算整数的阶乘.F#中一个简单的方法是:

let rec fact (n: bigint) =
    match n with
    | x when x = 0I -> 1I
    | _ -> n * fact (n-1I)
Run Code Online (Sandbox Code Playgroud)

但是,如果我的程序需要动态编程,那么在使用memoization时如何维持函数式编程呢?

我对此有一个想法是制作一系列懒惰元素,但我遇到了一个问题.假设以下代码在F#中是可接受的(它不是):

let rec facts = 
    seq {
        yield 1I
        for i in 1I..900I do 
            yield lazy (i * (facts |> Seq.item ((i-1I) |> int)))
    }
Run Code Online (Sandbox Code Playgroud)

F#中有什么类似的想法吗?(注意:我知道我可以使用.NET Dictionary而不是调用".Add()"方法命令式样式?)

另外,有什么办法可以用函数来概括这个吗?例如,我可以创建一个由函数定义的collat​​z函数的长度序列:

let rec collatz n i = 
    if n = 0 || n = 1 then (i+1)
    elif n % 2 = 0 …
Run Code Online (Sandbox Code Playgroud)

recursion f# functional-programming dynamic memoization

3
推荐指数
1
解决办法
430
查看次数