在javascript中对数字的n次方可以简写成
10**3 = 1000
代替101010。但是这种写法在v8中确有性能问题,尽量少用!
实验过程
- 源代码
let start_time = Date.now();
for(let a=0;a<1001;a++){
for(let b=0;b<1001;b++){
for(let c=0;c<1001;c++){
// ** 重点关注这一行
if(a**2 + b**2 == c**2 && a + b +c == 1000){
console.log(`a, b, c: ${a} ${b} ${c}`);
}
}
}
}
let end_time = Date.now();
console.log(`一共花费的时间为:${(end_time - start_time)/1000}s`);
console.log('结束!');
将上面代码改进 ** —> a*a 不再简写
let start_time = Date.now();
for(let a=0;a<1001;a++){
for(let b=0;b<1001;b++){
for(let c=0;c<1001;c++){
// 修改的这一行
if(a*a + b*b == c*c && a + b +c == 1000){
console.log(`a, b, c: ${a} ${b} ${c}`);
}
}
}
}
let end_time = Date.now();
console.log(`一共花费的时间为:${(end_time - start_time)/1000}s`);
console.log('结束!');
运行结果
- 在macOS上,使用node@v14.2
改进前:
a, b, c: 0 500 500
a, b, c: 200 375 425
a, b, c: 375 200 425
a, b, c: 500 0 500
一共花费的时间为:1.879s
结束!
改进后:
a, b, c: 0 500 500
a, b, c: 200 375 425
a, b, c: 375 200 425
a, b, c: 500 0 500
一共花费的时间为:0.781s
结束!
- 在linux上,使用node@v14.5
改进前:
a, b, c: 0 500 500
a, b, c: 200 375 425
a, b, c: 375 200 425
a, b, c: 500 0 500
一共花费的时间为:2.401s
结束!
改进后:
a, b, c: 0 500 500
a, b, c: 200 375 425
a, b, c: 375 200 425
a, b, c: 500 0 500
一共花费的时间为:0.995s
结束!
差距还是蛮大的!平时少用!