JavaScript 中数组引用陷阱与“破纪录”问题的正确解法
本文详解如何修复因数组引用导致的逻辑错误,通过深拷贝避免副作用,正确统计运动成绩中最高分和最低分的“破纪录”次数。 本文详解如何修复因数组引用导致的逻辑错误,通过深拷贝避免副作用,正确统计运动成绩中最高分和最低分的“破纪录”次数。在解决经典的「Breaking Records」问题(即统计某人连续比赛成绩中打破个人最高分和最低分的次数)时,一个常见但隐蔽的陷阱是数组的引用传递问题。原始代码看似逻辑清晰:分别定义 HP()(High Peak)和 LP()(Low Peak)函数来模拟遍历过程并计数;但实际运行结果却偏离预期(如输入 [10, 5, 20, 20, 4, 5, 2, 25, 1] 应输出 [2, 4],却得到错误值),根本原因在于:两个函数内部均直接赋值 var b = array 和 var a = array,导致它们操作的是同一份原始数组的引用副本。当 HP() 执行时,它调用 b.splice() 动态修改了数组内容——而由于 b 与外部 array 指向同一内存地址,后续 LP() 接收到的 array 已被污染,不再是原始输入。这破坏了算法的独立性假设,使两次扫描失去基准一致性。? 正确做法是:每次传入前创建数组的浅拷贝。JavaScript 中最简洁安全的方式是使用展开运算符 [...array]:function HP(array) { var b = [...array]; // ? 创建新数组,隔离副作用 let temp = b[0]; let count = 0; for (let i = 1; i < b.length; i++) { if (b[i] > temp) { temp = b[i]; count++; } } return count;}function LP(array) { var a = [...array]; // ? 同样独立拷贝 let temp = a[0]; let count = 0; for (let j = 1; j < a.length; j++) { if (a[j] < temp) { temp = a[j]; count++; } } return count;}? 注意:原代码中还存在多处潜在风险:立即学习“Java免费学习笔记(深入)”; 橙篇 百度文库发布的一款综合性AI创作工具
