为了账号安全,请及时绑定邮箱和手机立即绑定

给定一个值,如100,给定一个数组,从数组中挑选出N个元素,用javascript怎么实现呢

给定一个值,如100,给定一个数组,从数组中挑选出N个元素,用javascript怎么实现呢

米脂 2018-08-09 09:10:18
如数组:var arr = [99.1, 92.2, 60, 50,           49.5, 45.7, 25.1, 20,             17.4, 13, 10, 7, 2.1, 2, 1];找到和为100的数组元素,或者结果最接近100的组合:[60,20,10,7,2,1]
查看完整描述

1 回答

?
森栏

TA贡献1810条经验 获得超5个赞

    var arr = [99.1, 92.2, 60, 50,

            49.5, 45.7, 25.1, 20,

            17.4, 13, 10, 7, 2.1, 2, 1

        ];

        

    function combinations(array, n) {

    var lists = [],

        M = 1 << array.length;

    for (var i = 1; i < M; ++i) {

        var sublist = array.filter(function(c, k) {

            return i >> k & 1

        });

        if (sublist.reduce(function(p, c) {

                return p + c

            }, 0) === n)

            lists.push(sublist);

    }

    return lists;

}

        

console.log(combinations(arr, 100))

//[[60,20,13,7],[50,20,13,10,7],[49.5,25.1,17.4,7,1],[60,20,10,7,2,1],[49.5,20,17.4,10,2.1,1],[49.5,17.4,13,10,7,2.1,1]]


查看完整回答
反对 回复 2018-09-18
  • 1 回答
  • 0 关注
  • 706 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信