ホームページ  >  記事  >  バックエンド開発  >  このアルゴリズムの最適化されたバージョンを探しています。 ! ! !

このアルゴリズムの最適化されたバージョンを探しています。 ! ! !

WBOY
WBOYオリジナル
2016-07-25 08:48:45800ブラウズ
プロジェクトで遭遇した問題。
大きな配列にはいくつかの小さな配列がありますが、小さな配列は繰り返される可能性があり、インターフェイスは重複しない配列構造を返す必要があります。 PHPの組み込み関数array_merge()を試しましたが、小さな配列をソートできません。これが私の使い方です。効率が非常に低いとしか言​​えませんが、この記事をご覧になった方で良い方法があれば教えて下さい。 :)
//$hotel_setting には、繰り返される大きな配列が含まれる場合があります。
小さな配列構造は array('hotel_adt_cnt'=>'','hotel_chd_cnt'=>''); です。
  1. $hotel_unique = array();
  2. while ( 1 ) {
  3. $cmp = array_shift( $hotel_setting );
  4. $repeat = false;
  5. foreach ( $hotel_setting as $val ) {
  6. if ( $val[ 'hotel_adt_cnt'] == $cmp['hotel_adt_cnt'] && $val['hotel_chd_cnt'] == $cmp['hotel_chd_cnt']) {
  7. $repeat = true;
  8. Break;
  9. }
  10. }
  11. if(! $repeat)
  12. {
  13. $hotel_unique[] = $cmp;
  14. }
  15. if ( count( $hotel_setting ) == 0 ) {
  16. Break;
  17. }
  18. }
  19. $hotel_setting = $hotel_unique;
コードをコピー


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。