我们将编写一个 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()计算目标数字和最接近数字之间的差异。 Math.abs()返回数字的绝对值,确保差值始终为正。
然后我们使用 for 循环来迭代 numbers 数组。对于每次迭代,我们将当前数字存储在当前变量中,并在currentDiff中计算目标数字和当前数字之间的差异。
如果currentDiff小于closestDiff,我们将closest更新为当前并且closestDiff 为 currentDiff。
最后,函数返回最接近目标的数字。
以上是JavaScript 程序查找数组中最接近的数字的详细内容。更多信息请关注PHP中文网其他相关文章!