小编CxD*_*Doo的帖子

F# 中的函数模板

假设我正在解决一个特定的问题并提出一个函数

let function parameter1 ... = 
     a lot of adding, multiplying & so on with a lot of 
     literals all over the place
Run Code Online (Sandbox Code Playgroud)

现在,如果我的参数是 int 类型,这个函数就可以正常工作。但是在某个地方我需要将它提升到 11,我需要额外推动 int64 甚至 BigInteger。那我该怎么办?我复制并粘贴函数,更改名称,并寻找所有使编译器认为函数应该在 int 上运行的文字外观。这很糟糕。

有没有办法做到这一点:

let greatFunction param1 param2 = (param1+1)/(param2*2)
Run Code Online (Sandbox Code Playgroud)

其中 param1 和 param2 可以是整数类型的任何组合?

编辑:

通过下面的 kvb 对一个很棒的提示进行了扩展,我想出了以下内容

module NumericLiteralG 

  let inline FromZero() = LanguagePrimitives.GenericZero
  let inline FromOne() = LanguagePrimitives.GenericOne
  let inline FromInt32 n =
    let rec loop nIn nOut = 
        if nIn>0 then loop (nIn - 1) (nOut + …
Run Code Online (Sandbox Code Playgroud)

f# inline

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

C#中的Euler 23:0.2秒,F#:30.5秒.为什么?

我对这个问题的F#解决方案并不满意,因为我找不到一个漂亮而快速的解决方案,但这不是问题所在.问题是,我将解决方案转换为C#,因为它很快.喜欢,非常快,相对而言.

我无法弄清楚为什么.是的,我去过Reflector,C#代码看起来非常相似,不能说我真的了解IL但它看起来有点像.我唯一能想到的是F#int []对C#List的表现.

所以这里:

F#

module Euler023

let divisorsSum n =
  let mutable sum = 1
  let limit = (int (sqrt(float n)))
  for i in [2..limit] do
    if n%i=0 then sum <- sum+i+n/i
  if (limit*limit)=n then sum-limit else sum

let isAbundant x = (divisorsSum x)>x
let abundants  = [1..28123] |> List.filter isAbundant |> List.toArray
let domain = System.Collections.BitArray(28124)

let rec loopUntil i j =
    if i=abundants.Length then ()
    elif j=abundants.Length then loopUntil (i+1) (i+1)
    else
      let sum = abundants.[i]+abundants.[j] 
      if …
Run Code Online (Sandbox Code Playgroud)

c# f# c#-to-f#

2
推荐指数
1
解决办法
817
查看次数

标签 统计

f# ×2

c# ×1

c#-to-f# ×1

inline ×1