C/C++开发node扩展之优化累加求和


累加求和即从最小数开始一直加到最大数,例如:

1累加到100,即1+2+3……+100;

普通算法

1
2
3
for(int i = min, i <= max; i++) {
    sum += i;
}

下面是以扩展的形式开发的优化算法。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
#include <nan.h>    
void change(long long *num1, long long *num2){    
    *num1 = *num2 + *num1;    
    *num2 = *num1 - *num2;    
    *num1 = *num1 - *num2;    
}    
long long add(long long min, long long max){    
    if (min > max) {    
        change(&min, &max);    
    }    
    long long sum = 0;    
    long long addTimes = 0;    
    if ((min + max) % 2 == 0) {    
        addTimes = (max - min) / 2;    
        return addTimes * (max + min ) + (max + min ) /2;    
    } else {    
        addTimes = (max - min + 1) / 2;    
        return (max+min)*addTimes;    
    }    
}    
void accumulation(const Nan::FunctionCallbackInfo<v8::Value>& info) {    
    if (info.Length() < 2) {    
        Nan::ThrowTypeError("至少需要两个参数");    
        return;    
    }    
    if (!info[0]->IsNumber() || !info[1]->IsNumber()) {    
        Nan::ThrowTypeError("错误的参数");    
        return;    
    }    
    long long arg0 = (long long) info[0]->NumberValue();    
    long long arg1 = (long long) info[1]->NumberValue();    
    long long sum = 0;    
    sum = add(arg0, arg1);    
    char buf[100];    
    sprintf(buf,"%lld",sum);    
    v8::Local<v8::String> num = Nan::New(buf).ToLocalChecked();    
    info.GetReturnValue().Set(num);    
}    
void Init(v8::Local<v8::Object> exports) {    
    exports->Set(Nan::New("accumulation").ToLocalChecked(),    
    Nan::New<v8::FunctionTemplate>(accumulation)->GetFunction());    
}    
NODE_MODULE(accumulation, Init)

建立binding.gyp

1
2
3
4
5
6
7
8
9
10
11
{    
    "targets": [    
        {    
            "target_name": "accumulation",    
            "sources": [ "accumulation.cc" ],    
            "include_dirs": [    
                "<!(node -e \"require('nan')\")"    
            ]    
        }    
    ]    
}

编译生成node扩展可以参照:http://blog.okgoes.com/index/blog/detail/uuid/1030000202/type/17/t/1496558300/bid/46.html

源码下载:https://github.com/zyw327/accumulation