マッピングされた配列の対称差

JavaScriptJavaScriptBeginner
今すぐ練習

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

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

はじめに

この実験では、対称差の概念と、JavaScript で symmetricDifferenceBy() 関数を使ってそれを実装する方法を深く掘り下げます。この関数を使って、2 つの配列の各要素に提供された関数を適用した後、2 つの配列間の一意の値を見つける方法を探ります。この実験は、この強力な 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/AdvancedConceptsGroup -.-> javascript/higher_funcs("Higher-Order Functions") javascript/AdvancedConceptsGroup -.-> javascript/destr_assign("Destructuring Assignment") javascript/AdvancedConceptsGroup -.-> javascript/spread_rest("Spread and Rest Operators") subgraph Lab Skills javascript/variables -.-> lab-28487{{"マッピングされた配列の対称差"}} javascript/data_types -.-> lab-28487{{"マッピングされた配列の対称差"}} javascript/arith_ops -.-> lab-28487{{"マッピングされた配列の対称差"}} javascript/comp_ops -.-> lab-28487{{"マッピングされた配列の対称差"}} javascript/higher_funcs -.-> lab-28487{{"マッピングされた配列の対称差"}} javascript/destr_assign -.-> lab-28487{{"マッピングされた配列の対称差"}} javascript/spread_rest -.-> lab-28487{{"マッピングされた配列の対称差"}} end

マッピングされた配列の対称差

コーディングを始めるには、ターミナル/SSH を開き、node と入力します。

この関数は、2 つの配列の各要素に提供された関数を適用した後、それらの対称差を返します。その仕組みは次の通りです。

  • 各配列から Set を作成して、それぞれに fn を適用した後の一意の値を取得します。
  • それぞれに対して Array.prototype.filter() を使って、もう一方に含まれていない値のみを残します。

ここに symmetricDifferenceBy 関数のコードを示します。

const symmetricDifferenceBy = (a, b, fn) => {
  const sA = new Set(a.map((v) => fn(v))),
    sB = new Set(b.map((v) => fn(v)));
  return [
    ...a.filter((x) => !sB.has(fn(x))),
    ...b.filter((x) => !sA.has(fn(x)))
  ];
};

symmetricDifferenceBy を次のように使うことができます。

symmetricDifferenceBy([2.1, 1.2], [2.3, 3.4], Math.floor); // [ 1.2, 3.4 ]
symmetricDifferenceBy(
  [{ id: 1 }, { id: 2 }, { id: 3 }],
  [{ id: 1 }, { id: 2 }, { id: 4 }],
  (i) => i.id
);
// [{ id: 3 }, { id: 4 }]

まとめ

おめでとうございます!あなたはマッピングされた配列の対称差の実験を完了しました。あなたのスキルを向上させるために、LabEx でさらに多くの実験を行って練習することができます。