既然Python可以计算2的100次方,那么我就要用VBS实现。不过这个效率嘛,计算2的10000次方Python用了0.009013秒,VBS用了120.9805秒,不是一个等级的,我就不多说什么了。

直接上代码:


复制代码 代码如下:

‘Date: 2010/10/27

‘Author: Demon

‘QQ: 380401911

‘E-mail: still.demon@gmail.com

begin = Timer

n = 1

For i = 1 To 100

n = multiple(n, 2)

Next

finish = Timer

WScript.Echo n

WScript.Echo finish – begin

‘Grade school multiplication, Algorithm 14.12

‘http://www.cacr.math.uwaterloo.ca/hac/about/chap14.pdf

Function multiple(byVal x, byVal y)

Dim n, t, i, j, z, w()

n = Len(x) – 1

t = Len(y) – 1

ReDim w(n + t + 1)

x = CStr(x) : y = CStr(y)

For i = 0 To UBound(w)

w(i) = “0”

Next

For i = 0 To t

Dim c : c = 0

Dim uv : uv = 0

For j = 0 To n

uv = (w(i+j)-“0”) + c + _

(Mid(x,n-j+1,1)-“0”) * (Mid(y,t-i+1,1)-“0”)

w(i+j) = CStr(uv Mod 10 + “0”)

c = uv \ 10

Next

w(i+n+1) = CStr(uv \ 10 + “0”)

Next

z = Join(w,””)

z = StrReverse(z)

Do While Left(z,1) = “0”

z = Mid(z,2)

Loop

multiple = z

End Function

原文:http://demon.tw/programming/vbs-long-multiplication.html
您可能感兴趣的文章:

声明:本站(华域联盟www.cnhackhy.com)所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。