JavaScript 查找数组中最接近的数
我们将编写一个JavaScript程序,通过将每个元素与目标数字进行比较并跟踪最接近的数字,来查找数组中最接近的数字。程序将使用循环遍历数组中的每个元素,并使用条件语句来比较目标数字和当前元素之间的差异。如果差异比当前最接近差异小,我们将更新最接近的数字。该程序的结果将是给定数组中最接近目标数字的数字。
方法
该程序将在数字数组中找到最接近目标值的数字 –
- 定义一个变量来存储循环中目标值和当前值之间的差异。
-
将差异设置为一个非常大的数,这样数组中的任何数都会比它小,并成为新的最接近数。
-
遍历数字数组,对于每个数字计算目标值和当前数之间的绝对差值。
-
如果当前差异小于存储的差异,则将存储的差异更新为当前差异,并将当前数字存储为最接近的数字。
-
对数组中的所有数字重复此过程。
-
循环结束后,最接近目标值的数字是存储在变量中的数字。
示例
这是一个JavaScript函数的示例,该函数接受数字数组和目标数字作为输入,并返回数组中最接近目标数字的数字 –
function findClosest(numbers, target) {
let closest = numbers[0];
// Assume the first number is the closest
let closestDiff = Math.abs(target - closest);
// Calculate the difference between the target and closest
for (let i = 1; i < numbers.length; i++) {
let current = numbers[i];
let currentDiff = Math.abs(target - current);
// Calculate the difference between the target and current number
if (currentDiff < closestDiff) {
closest = current;
// Update the closest number
closestDiff = currentDiff;
// Update the closest difference
}
}
return closest;
}
const arr = [45, 23, 25, 78, 32, 56, 12];
const target = 50;
console.log(findClosest(arr, target));
解释
-
函数 findClosest 接收两个参数:一个数字数组和目标数字 target。
-
我们创建一个变量 closest 并将其设为数字数组 numbers 中的第一个数字,并假设这是距离目标最近的数字。
-
我们还创建一个变量 closestDiff ,使用 Math.abs()。 计算目标数字与最接近数字之间的差值。
-
然后,我们使用for循环遍历 numbers 数组。在每次迭代中,我们将当前数字存储在变量 current 中,并计算目标和当前数字之间的差值 currentDiff。
-
如果 currentDiff 小于 closestDiff ,我们更新 closest 为 current ,并将 closestDiff 更新为 currentDiff。
-
最后,函数返回距离目标最近的数字。