性能优化
var array = [];
for (let index = 0; index < array.length; index++) {
// do something
}
// 优化后
for (let index = 0, len = array.length; index < len; index++) {
// do something
}
算法优化
// 求和:1 + 2 + 3 + 4 +... + 100
var sum = 0;
for (let i = 1; i <= 100; i++) {
sum += i;
}
console.log(sum); // 5050
// 等差数列公式求和公式 Sn=n(a1+an)/2
console.log(((1 + 100) * 100) / 2); // 5050
例题:找出两个数,和为11,返回下标
var list = [1, 7, 3, 4, 5, 6];
方式一:
var loop = 0;
for (let i = 0; i < list.length; i++) {
for (let j = 0; j < list.length; j++) {
if (list[i] + list[j] == 11) {
console.log(i, j);
// 1 3, 3 1, 4 5, 5 4
}
console.log("loop", ++loop);
// loop 36
}
}
方式二:
var loop = 0;
for (let i = 0; i < list.length; i++) {
let index = list.indexOf(11 - list[i]);
if (index > -1) {
console.log(i, index);
// 1 3, 3 1, 4 5, 5 4
}
console.log("loop", ++loop);
// loop 6
}