Javascript
 Computer >> コンピューター >  >> プログラミング >> Javascript

JavaScriptで配列内の要素のデカルト積を計算する


デカルト積

A×Bで表される2つのセット(配列)AとBのデカルト積は、aがAにあり、bがBにあるすべての順序対(a、b)のセット(配列)です。

簡単に言うと、2つの配列のデカルト積は、最初の要素が最初の配列に属し、2番目の要素が2番目の配列に属する2つの要素のすべての可能な配列の順列です。

たとえば、-2つの配列が-

の場合
const arr1 = [1, 2, 3];
const arr2 = [4, 5];

その場合、デカルト積は-

になります。
const product = [[1, 4], [1, 5], [2, 4], [2, 5], [3, 4], [3, 5]];

このためのコードは-

になります
const arr1 = [1, 2, 3];
const arr2 = [4, 5];
const cartesianProduct = (arr1, arr2) => {
   const res = [];
   for(let i = 0; i < arr1.length; i++){
      for(let j = 0; j < arr2.length; j++){
         res.push(
            [arr1[i]].concat(arr2[j])
         );
      };
   };
   return res;
};
console.log(cartesianProduct(arr1, arr2));

出力

そして、コンソールの出力は-

になります
[ [ 1, 4 ], [ 1, 5 ], [ 2, 4 ], [ 2, 5 ], [ 3, 4 ], [ 3, 5 ] ]

  1. JavaScriptで配列要素をすべての確率に減らす

    問題 配列を受け取るJavaScript関数を作成する必要があります。この関数は、次のように配列番号を変更する必要があります- 数値が奇数の場合は、変更したままにします。 数値が偶数の場合は、1を引きます。 そして、新しい配列を返す必要があります。 例 以下はコードです- const arr = [5, 23, 6, 3, 66, 12, 8]; const reduceToOdd = (arr = []) => {    const res = [];    for(let i = 0; i < arr.length; i++){

  2. JavaScriptで配列要素を交互に組み合わせる

    問題 リテラルの任意の数の配列を入力として受け取るJavaScript関数を作成する必要があります。 この関数は、すべての入力配列から交互に選択された要素を含む新しい配列を準備する必要があります。 たとえば、関数への入力が-の場合 入力 const arr1 = [1, 2, 3, 4]; const arr2 = [11, 12, 13, 14]; const arr3 = ['a', 'b', 'c']; 出力 const output = [1, 11, 'a', 2, 12, 'b', 3,