配列要素の検索効率を向上させる
1.phpのin_arrayメソッドの説明
php 配列要素が存在するかどうかを調べるには、一般的に in_array メソッドが使用されます。
リーリーパラメータの説明:
針
検索する値。needle が文字列の場合、比較では大文字と小文字が区別されます。
干し草の山
比較に使用される配列
厳しい
3 番目のパラメーター strict の値が TRUE の場合、in_array() 関数は針の種類が干し草の山のものと同じかどうかもチェックします
戻り値
針が見つかった場合は TRUE を返し、そうでない場合は FALSE を返します。
2.in_array 内の要素の検索効率
比較される配列の干し草の山が大きい場合、in_array の効率は非常に低くなります
例: in_array を使用して、100,000 要素の配列に対して 1,000 回の比較を実行します
リーリー リーリー要素が存在するかどうかを判断するには in_array を使用します。100,000 要素の配列で 1000 回比較します。実行時間は約 2 秒かかります。
3. 要素の検索効率を向上させる方法
例: array_flip を使用して最初にキーと値の交換を実行し、次に isset メソッドを使用して判定し、100,000 要素の配列で 1000 回比較します
リーリー リーリー
array_flip と isset を使用して、100,000 要素の配列を 1,000 回比較します。実行時間は約 1.2 ミリ秒です。 したがって、大きな配列を比較する場合、array_flip メソッドと isset メソッドを使用する方が in_array よりもはるかに効率的になります。
素早く体重を減らします
1. array_unique メソッドを使用して重複を削除します
配列要素を重複排除するには、通常、array_unique メソッドを使用します。このメソッドを使用すると、配列内の要素を重複排除できます。
出力:
リーリー重複排除後、キー値の順序は変わります。array_values を使用してキー値を並べ替えることができます。
2. array_unique メソッドを使用して複製の効率を下げます
リーリー
リーリー
array_unique メソッドを使用して重複を削除します。実行時間は約 650 ミリ秒、メモリ使用量は約 5 ミリ秒です。
php にはキーと値の交換メソッド array_flip があり、このメソッドを使用してキーと値の交換を行うため、元の重複した値は同じキーになります。
次に、キーと値の交換を再度実行し、キーと値を元に戻して重複排除を完了します。
array_flip メソッドを使用して重複を削除します。実行時間は約 18 ミリ秒、メモリ使用量は約 2 ミリ秒です。
したがって、array_flip メソッドを使用して重複を削除すると、array_unique メソッドを使用した場合と比較して、実行時間が 98% 短縮され、メモリ使用量が 4/5 削減されます。
興味があるかもしれない記事: php 配列内の指定された値を見つけるメソッド php 配列検索関数 in_array()、array_search()、array_key_exists() の使用例
www.bkjia.com