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

JavaScriptで変換を行った後に最小の合計を見つける


問題

正の整数の配列を受け取るJavaScript関数を作成する必要があります。次の操作を必要な回数だけ実行することで、要素を変換できます-

if arr[i] > arr[j] then arr[i] = arr[i] - arr[j]

これ以上変換が不可能な場合、関数はその合計を返す必要があります。

以下はコードです-

const arr = [6, 9, 21];
const smallestSum = (arr = []) => {
   const equalNums = arr => arr.reduce((a, b) => {
      return (a === b) ? a : NaN;
   });
   if(equalNums(arr)){
      return arr.reduce((a, b) => {
         return a + b;
      });
   }else{
      const sorted = arr.sort((a, b) => {
         return a-b;
      });
      const last = sorted[arr.length-1] - sorted[0]
      sorted.pop();
      sorted.push(last);
      return smallestSum(sorted);
   };
};
console.log(smallestSum(arr));

出力

以下はコンソール出力です-

9

  1. JavaScriptでエレベータがカバーするフロアの合計を見つける

    問題 建物のエレベーターが一定時間停止した階数を表す配列を受け取るJavaScript関数を作成する必要があります。 そのデータから、関数はその時間にリフトでカバーされたフロアの総数を返す必要があります。 例 以下はコードです- const arr = [7, 1, 7, 1]; const floorsCovered = (arr = []) => {    let res = 0;    for (let i = 0; i < arr.length; i++){       if (arr[i] >

  2. JavaScriptで角かっこのスコアを見つける

    問題 最初で唯一の引数として、バランスの取れた角括弧文字列strを受け取るJavaScript関数を作成する必要があります。 この関数は、次のルールに基づいて文字列のスコアを計算して返す必要があります- []スコアは1です ABのスコアはA+Bで、AとBはバランスの取れたブラケット文字列です。 [A]のスコアは2*Aです。ここで、Aはバランスの取れたブラケット文字列です。 たとえば、関数への入力が 入力 const str = '[][]'; 出力 const output = 2; 例 以下はコードです- const findScore