在多维数组中找到两个相关数字的最接近组合

Find the closest combination of two related numbers in a multidimensional array

我需要根据用户输入搜索并比较多维数组中两个数字的最近组合。

目前我有类似的东西可以找到最接近的匹配号码 "one number"。

var count= [10, 20, 30, 40],

  goal = userinput

  var closest = count.reduce(function(prev, curr) {
    return (Math.abs(curr - goal) < Math.abs(prev - goal) ? curr : prev);
  });

$('#result').attr('value', closest);

我想做的事情:当用户在 userinput1 中输入 194 in userinput2 应该是在多维数组中搜索比较最近的数字组合计数.

<input id="userinput1 " value="19" type="text">
<input id="userinput2 " value="4" type="text">

-

var userinput1 = $('#userinput1 ').val();
var userinput2 = $('#userinput2 ').val();

counts = [['10', '5'], ['20', '10']];

goal = [[userinput1, userinput2]];

/* NEEDED SCRIPT */

$('#result1').attr('value', closest1);
$('#result2').attr('value', closest2);

在这个例子中,它应该选择 ['20', '10'] 并在不同的变量中输出两个数字。

HTML 结果应该是:

<input id="result1" value="20" type="text">
<input id="result2" value="10" type="text">

为了比较索引方式的绝对 depats,您可以先获取增量,然后 return 根据总和获取数组。

const addAbsDelta = g => (s, v, i) => s + Math.abs(v - g[i]);

var counts = [[10, 5], [20, 10]],
    goal = [19, 4],
    result = counts.reduce((a, b) =>
        a.reduce(addAbsDelta(goal), 0) < b.reduce(addAbsDelta(goal), 0) ? a : b
    );
    
console.log(result);

要获得其中一个值匹配的结果,您需要获得绝对增量与结果顺序的绝对增量之和的乘积,并取最小值。

function getApproximation(counts, goal) {
    const
        p = (r, v, i) => r * Math.abs(v - goal[i]),   // moves zeros to top
        s = (r, v, i) => r + Math.abs(v - goal[i]),   // allowes sorting
        score = a => a.reduce(p, 1) + a.reduce(s, 0); // get product and sum

    return counts
        .filter(a => goal.every((g, i) => a[i] >= g))
        .reduce((a, b) => score(a) <= score(b) ? a : b);
}

var counts = [[5300, 4.2], [6800, 6.0], [5650, 6.6], [2600, 7.0], [4700, 7.0], [3250, 7.3], [3800, 7.5], [3300, 7.8], [9000, 8.2], [5700, 8.5], [7400, 8.5], [6900, 8.7], [4300, 9.0], [5000, 9.5], [6000, 9.5], [7700, 9.5], [2750, 10.0], [5300, 10.0], [6500, 10.0], [8900, 10.5], [6800, 11.0], [3600, 11.4], [4500, 11.5], [9500, 11.5], [5700, 12.0], [5000, 24.0], [6500, 27.0], [7900, 30.0], [5700, 31.0]];

console.log(getApproximation(counts, [2000, 5]));  // [2600, 7]
console.log(getApproximation(counts, [2000, 30])); // [7900, 30]
console.log(getApproximation(counts, [2600, 30])); // [7900, 30] 

只需添加相应数组元素的差异,并像之前那样将其最小化。

var userinput1 = $('#userinput1 ').val();
var userinput2 = $('#userinput2 ').val();

counts = [
  ['10', '5'],
  ['20', '10']
];

goal = [userinput1, userinput2];

let closest = counts[0];
let prevDiff = Math.abs(closest[0] - goal[0]) + Math.abs(closest[1] - goal[1]);
counts.forEach(c => {
  let curDiff = Math.abs(c[0] - goal[0]) + Math.abs(c[1] - goal[1]);
  if (curDiff < prevDiff) {
    closest = c;
    prevDiff = curDiff;
  }
});

$('#result1').val(closest[0]);
$('#result2').val(closest[1]);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
Input:
<input id="userinput1 " value="19" type="text">
<input id="userinput2 " value="4" type="text">
Output:
<input id="result1" type="text">
<input id="result2" type="text">