性能优化
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 }