JavaScriptでよく使われる配列重複排除実戦ソースコード

JavaScriptでよく使われる配列重複排除実戦ソースコード

アレイの重複排除は、通常、就職面接中に遭遇し、アレイの重複排除方法のコードを手動で記述することが求められます。アレイの重複を排除する方法は何ですか? 10 個の質問に答えることができれば、面接官はあなたに好印象を持つでしょう。
実際のプロジェクトでは、配列の重複排除は通常バックグラウンドで処理され、フロントエンドで処理されることはほとんどありません。日常的なプロジェクトで使用する可能性は比較的低いですが、面接中に質問された場合に備えて理解しておく必要があります。

1. オブジェクトプロパティの使用

オブジェクトの一意の属性名機能を使用します。

var arr = ['qiang','ming','tao','li','liang','you','qiang','tao'];
console.time("非冗長1");
var nonredundant1 = Object.getOwnPropertyNames(arr.reduce(function(seed, item, index) {
    seed[item] = インデックス;
    シードを返します。
},{}));
console.timeEnd("非冗長1");
console.log(非冗長1);

結果は次のとおりです。

8つのよく使われるJavaScript配列重複排除の実践的なソースコード「実用的な乾物」

2. セットデータ構造の使用

セットは配列に似た構造ですが、セットのメンバーには重複する値は存在しません。 set() 関数は、配列または配列のようなパラメータを受け入れて、セット オブジェクトを生成できます。 Array.from メソッドは、2 種類のオブジェクト (配列のようなオブジェクト (配列のようなオブジェクトと反復可能なオブジェクト)、ES6 で追加されたデータ構造 Set および Map を含む) を実際の配列に変換するために使用されます。

var arr = ['qiang','ming','tao','li','liang','you','qiang','tao'];
関数 unique(arr) {
    Array.from(new Set(arr)) を返します
}
console.time("非冗長2");
var nonredundant2 = unique(arr);
console.timeEnd("非冗長2");
console.log(非冗長2);

結果は次のとおりです。

8つのよく使われるJavaScript配列重複排除の実践的なソースコード「実用的な乾物」

3. forループとスプライスの使用

関数 unique(arr) {
    (var i = 0; i < arr.length; i++) の場合 {
        (var j = i + 1; j < arr.length; j++) の場合 {
            if (arr[i] == arr[j]) { // 最初のものは 2 番目のものと等しいので、splice メソッドは 2 番目のものを削除します arr.splice(j, 1);
                j--;
            }
        }
    }
    arr を返します。
}
console.time("非冗長3");
var arr = ['qiang', 'ming', 'tao', 'li', 'liang', 'you', 'qiang', 'tao'];
var nonredundant3 = unique(arr);
console.timeEnd("nonredundant3");
console.log(非冗長3);

結果は次のとおりです。

8つのよく使われるJavaScript配列重複排除の実践的なソースコード「実用的な乾物」

4. indexOfを使用して重複の削除を決定する

関数 unique(arr) {
    var 配列 = [];
    (var i = 0; i < arr.length; i++) の場合 {
        配列のindexOf(arr[i]) === -1の場合{
            配列.push(arr[i])
        }
    }
    配列を返します。
}
var arr = ['qiang', 'ming', 'tao', 'li', 'liang', 'you', 'qiang', 'tao'];
console.time("非冗長4");
var nonredundant4 = unique(arr);
console.timeEnd("非冗長4");
console.log(非冗長4);

結果は次のとおりです。

8つのよく使われるJavaScript配列重複排除の実践的なソースコード「実用的な乾物」

5. 並べ替えを使用して重複を並べ替えて削除する

関数 unique(arr) {
    arr = arr.sort()
    var arry = [arr[0]];
    (var i = 1; i < arr.length; i++) の場合 {
        もし (arr[i] !== arr[i - 1]) {
            arrry.push(arr[i]);
        }
    }
    リターン arry;
}
 
var arr = ['qiang', 'ming', 'tao', 'li', 'liang', 'you', 'qiang', 'tao'];
console.time("非冗長5");
var nonredundant5 = unique(arr);
console.timeEnd("非冗長5");

結果は次のとおりです。

8つのよく使われるJavaScript配列重複排除の実践的なソースコード「実用的な乾物」

6. フィルターを使用する

関数 unique(arr) {
    var obj = {};
    arr.filter(function(item, index, arr){ を返します。
        obj.hasOwnProperty(typeof item + item) を返します。false の場合: (obj[typeof item + item] = true)
    })
}
var arr = ['qiang', 'ming', 'tao', 'li', 'liang', 'you', 'qiang', 'tao'];
console.time("非冗長6");
var nonredundant6 = unique(arr);
console.timeEnd("非冗長6");
console.log(非冗長6);

結果は次のとおりです。

8つのよく使われるJavaScript配列重複排除の実践的なソースコード「実用的な乾物」

7. マップデータ構造を使用して重複を削除する

関数 unique(arr) {
    map = new Map();
    let array = new Array(); // 配列は結果を返すために使用されます for (let i = 0; i < arr.length; i++) {
        if (map.has(arr[i])) { // キー値がある場合 map.set(arr[i], true);
        } それ以外 {
            map.set(arr[i], false); // そのようなキー値が存在しない場合はarr.push(arr[i]);
        }
    }
    配列を返します。
}
 
var arr = ['qiang', 'ming', 'tao', 'li', 'liang', 'you', 'qiang', 'tao'];
console.time("非冗長7");
var nonredundant7 = unique(arr);
console.timeEnd("非冗長7");
console.log(非冗長7);

結果は次のとおりです。

8つのよく使われるJavaScript配列重複排除の実践的なソースコード「実用的な乾物」

8. 重複を削除するにはreduceとincludeを使用する

関数 unique(arr){
    arr.reduce((prev,cur) => prev.includes(cur) ? prev : [...prev,cur],[]); を返します。
}
var arr = ['qiang', 'ming', 'tao', 'li', 'liang', 'you', 'qiang', 'tao'];
console.time("非冗長8");
var nonredundant8 = unique(arr);
console.timeEnd("非冗長8");
console.log(非冗長8);

結果は次のとおりです。

8つのよく使われるJavaScript配列重複排除の実践的なソースコード「実用的な乾物」

よく使われる JavaScript 配列重複排除の実践的なソースコードに関するこの記事はこれで終わりです。より関連性の高い js 配列重複排除コンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • JavaScript 配列重複排除問題の詳細な研究
  • JavaScript 配列重複排除ソリューション
  • Javascript配列の重複排除のいくつかの方法の詳細な説明
  • JavaScript配列重複排除の詳細な説明
  • JS オブジェクト配列の重複排除のための 3 つの方法の例と比較
  • jsは多次元配列を1次元配列に変換し、それを並べ替えます
  • JavaScript配列の重複排除のいくつかの方法についての詳細な説明

<<:  Linuxでのcrontabの使い方と注意点の詳しい説明

>>:  OEL7.6 ソースコードから MYSQL5.7 をインストールするチュートリアル

推薦する

MySQL データ型 DECIMAL(N,M) における N と M の意味の詳細な説明

同僚から、MySQL データ型 DECIMAL(N,M) の N と M の意味を尋ねられました。言...

設計仕様に準拠した設計は良い設計でしょうか?

これまでの数年間、私はいわゆる「設計仕様」についてかなりの数の執筆やコンサルティングを行ってきました...

Linux でのルーティングと仮想マシン ネットワークの設定に関する詳細なグラフィック説明

ルーティングとは何ですか?ルーティングとは、相互接続されたネットワークを介して送信元ステーションから...

ローカル写真をアップロードする前にプレビューコード例を実装するための HTML5 と jQuery

HTML5 と jQuery はアップロード前にローカル画像のプレビューを実装しており、その効果は...

MySQLバックアップとリカバリの実践に関する詳細な説明

1. mysqlbackup の紹介mysqlbackup は、MySQL Enterprise B...

「いいね!」文がインデックスに登録されないのはなぜですか?

序文この記事は、最も人気のある言語で最も退屈な基礎知識を説明することを目的としていますこのトピックは...

実用的な基本的な Linux sed コマンドのサンプルコード

Linux ストリーム エディターは、データ センターでスクリプトを実行するのに便利な方法です。これ...

JavaScript で矢印関数を使用できないシナリオはどれですか

目次1. オブジェクトメソッドを定義する2. プロトタイプメソッドを定義する3. イベントコールバッ...

MySQL 増分バックアップとブレークポイントリカバリスクリプトの例

導入増分バックアップとは、完全バックアップまたは最後の増分バックアップの後、後続の各バックアップでは...

CSS プロパティ display:flow-root 宣言を 1 つの記事でマスターする

zhangxinxu より https://www.zhangxinxu.com/wordpress...

vue2.x の徹底研究 - h 関数の説明

目次解決、要約: vue プロジェクト。 .vue ファイルのテンプレート内に記述されたコードは、w...

Reactフックとzarmコンポーネントライブラリ構成に基づいてh5フォームページを開発するためのサンプルコード

最近、React Hooks を zarm コンポーネント ライブラリと組み合わせて使用​​し、js...

CSS のマージンの崩壊問題を解決する方法

まず、マージン崩壊が発生する 3 つの状況を見てみましょう。 1. 隣接する 2 つのブロックレベル...

Linux の who コマンド例の紹介

誰についてシステムにログインしているユーザーを表示します。 who コマンドを実行すると、現在システ...

MySQLデュアルマシンホットスタンバイと負荷分散の実装手順の詳細説明

MySQL データベースには増分バックアップ メカニズムはありませんが、マスター データベース内のす...