在数组中查找可能的附加组合

时间:2014-04-19 12:14:35

标签: javascript arrays algorithm array-algorithms

解决此问题的最佳方法是什么?我不知道如何开始。这不是一个家庭作业问题,而是采访的实践。

'使用JavaScript语言,让函数ArrayAddition(arr)获取存储在arr中的数字数组,如果数组中的任何数字组合可以加到数组中的最大数字,则返回字符串true,否则返回字符串false。例如:如果arr包含[4,6,23,10,1,3],则输出应返回true,因为4 + 6 + 10 + 3 = 23.数组不会为空,不包含所有相同的元素,并且可能包含负数。 “

http://coderbyte.com/CodingArea/GuestEditor.php?ct=Array%20Addition&lan=JavaScript

2 个答案:

答案 0 :(得分:0)

试试这个解决方案。对于此代码,我使用此引用github

<script type="text/javascript">

var bol=false
var arr=[4, 6, 23, 10, 1, 3]
var maxx=Math.max.apply(Math, arr);
var index = arr.indexOf(maxx);
arr.splice(index, 1);


function k_combinations(set, k) {
    var i, j, combs, head, tailcombs;
    if (k > set.length || k <= 0) {
        return [];
    }
    if (k == set.length) {
        return [set];
    }
    if (k == 1) {
        combs = [];
        for (i = 0; i < set.length; i++) {
        combs.push([set[i]]);
    }
    return combs;
    }
    combs = [];
    for (i = 0; i < set.length - k + 1; i++) {
        head = set.slice(i, i+1);
        tailcombs = k_combinations(set.slice(i + 1), k - 1);
        for (j = 0; j < tailcombs.length; j++) {
            combs.push(head.concat(tailcombs[j]));
        }
    }
    return combs;
}


function combinations(set) {
    var k, i, combs, k_combs;
    combs = [];
    for (k = 1; k <= set.length; k++) {
        k_combs = k_combinations(set, k);
        for (i = 0; i < k_combs.length; i++) {
            combs.push(k_combs[i]);
      }
    }
    return combs;
}
var result=combinations(arr)


for(z=0;z<result.length;z++){
    var tot=0
    for(c=0;c<result[z].length;c++){
        tot+=result[z][c]
    }
    if(tot===maxx){bol=true}
}

console.log(bol)


</script>

如果此解决方案不符合您的需求,我会为您浪费时间而道歉。

答案 1 :(得分:0)

试试这个解决方案。对于组合代码,我使用了此引用github

<script>
function algorithem() {    
        var arr = [4, 6, 23, 10, 1, 3];
        arr.sort(function(a,b) { return a-b } );
        var largest = arr[arr.length-1];
        arr.pop();

         function combinations(set) {
          return (function acc(xs, set) {
            var x = xs[0];
            if(typeof x === "undefined")
              return set;
            for(var i = 0, l = set.length; i < l; ++i)
              set.push(set[i].concat(x));
            return acc(xs.slice(1), set);
          })(set, [[]]).slice(1);
        };

        function add(arr) {
                   var sum = 0;
                var len = arr.length;
              for( var j=0;j<len;j++){
                    var p = arr[j];
                    for(var i=0,sum=0; i<p.length;i++){
                        sum += p[i];
                        if(largest == sum){
                            return true;

                        }
                    }
              };
              if( j == len){return false;}
        }
        add(combinations(arr));
    };
   </script>