JavaScript の reduce を使った配列の分割

JavaScriptJavaScriptBeginner
今すぐ練習

This tutorial is from open-source community. Access the source code

💡 このチュートリアルは英語版からAIによって翻訳されています。原文を確認するには、 ここをクリックしてください

はじめに

この実験では、JavaScript を使って、提供された関数に基づいて配列を分割する方法を探ります。提供された関数の出力の変化をチェックしながら、分割された値を配列に蓄積するために Array.prototype.reduce() メソッドを使用します。この実験が終了するとき、JavaScript で配列を分割する方法を十分に理解していることになります。


Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL javascript(("JavaScript")) -.-> javascript/BasicConceptsGroup(["Basic Concepts"]) javascript(("JavaScript")) -.-> javascript/AdvancedConceptsGroup(["Advanced Concepts"]) javascript/BasicConceptsGroup -.-> javascript/variables("Variables") javascript/BasicConceptsGroup -.-> javascript/data_types("Data Types") javascript/BasicConceptsGroup -.-> javascript/arith_ops("Arithmetic Operators") javascript/BasicConceptsGroup -.-> javascript/comp_ops("Comparison Operators") javascript/BasicConceptsGroup -.-> javascript/cond_stmts("Conditional Statements") javascript/AdvancedConceptsGroup -.-> javascript/higher_funcs("Higher-Order Functions") javascript/AdvancedConceptsGroup -.-> javascript/destr_assign("Destructuring Assignment") subgraph Lab Skills javascript/variables -.-> lab-28541{{"JavaScript の reduce を使った配列の分割"}} javascript/data_types -.-> lab-28541{{"JavaScript の reduce を使った配列の分割"}} javascript/arith_ops -.-> lab-28541{{"JavaScript の reduce を使った配列の分割"}} javascript/comp_ops -.-> lab-28541{{"JavaScript の reduce を使った配列の分割"}} javascript/cond_stmts -.-> lab-28541{{"JavaScript の reduce を使った配列の分割"}} javascript/higher_funcs -.-> lab-28541{{"JavaScript の reduce を使った配列の分割"}} javascript/destr_assign -.-> lab-28541{{"JavaScript の reduce を使った配列の分割"}} end

配列を分割するアルゴリズム

配列を分割するには、次の手順に従います。

  1. ターミナル/SSH を開き、コーディングを練習するために node と入力します。
  2. 与えられた配列 arr の各値に対して、提供された関数 fn を適用します。
  3. fn が新しい値を返すたびに、配列を分割します。
  4. Array.prototype.reduce() を使用して、結果の配列と fn から返された最後の値を保持する累積オブジェクトを作成します。
  5. Array.prototype.push() を使用して、arr の各値を累積配列の適切なパーティションに追加します。
  6. 結果の配列を返します。

以下はコードの実装です。

const partitionBy = (arr, fn) =>
  arr.reduce(
    ({ res, last }, v, i, a) => {
      const next = fn(v, i, a);
      if (next !== last) res.push([v]);
      else res[res.length - 1].push(v);
      return { res, last: next };
    },
    { res: [] }
  ).res;

使用例:

const numbers = [1, 1, 3, 3, 4, 5, 5, 5];
partitionBy(numbers, (n) => n % 2 === 0); // [[1, 1, 3, 3], [4], [5, 5, 5]]
partitionBy(numbers, (n) => n); // [[1, 1], [3, 3], [4], [5, 5, 5]]

まとめ

おめでとうございます!配列を分割する実験を完了しました。技術力を向上させるために、LabExでさらに実験を行って練習してください。