PHPの基数ソート方法
この記事では、主に PHP で基数ソートを実装する方法を紹介し、例の形で基数ソートの原理、実装方法、および関連する操作スキルを分析します。必要な友人は参考にしてください。 PHP で基数ソートを実装する方法。参考のために皆さんと共有してください。詳細は次のとおりです:
基数ソートは、キーワード内の各キーワードの値に基づいており、ソートされた N 個の要素に対して「配布」と「収集」の複数のパスを実行することによってソートされます。 。
具体的な例を使用して、基数ソートがどのように実行されるかを示しましょう。
初期シーケンスが R {50, 123, 543, 187, 49, 30, 0, 2, 11, 100} であると仮定します。
どのアラビア数字でも、各桁の底は 0 ~ 9 で表されることがわかっています。
つまり、0 ~ 9 を 10 個のバケットとみなした方がよいでしょう。
まずシーケンスの一桁の数字に従って分類し、指定されたバケットに分割します。例: R[0] = 50、1 桁は 0、この数値を 0 番のバケットに保存します。
分類後、各バケツから0番から9番まで順番にすべての番号を取り出します。
この時、得られた系列は一桁の増加傾向を持つ系列となっています。
1 桁で並べ替えます: {50、30、0、100、11、2、123、543、187、49}。
次に、この方法で十の位と百の位を並べ替えると、最終的に並べ替えられた順序が得られます。
<?php /**基数排序**/ /* * 获取第几位上的数字 * *百位数 = 2345%1000/100 */ function getN($num,$N){ $value = 10; for($i=1;$i<$N;$i++){ $value = $value * 10; } $M = (int)(($num % $value /($value/10))); return $M; } /* */ function paixu($arr) { $flag = 1;//该次位数上是否全为0标志位,全为0 flag=0 for($M=1;$flag!=0;$M++) { $flag = 0; if($M > 1){ $m = 0; for($j=0;$j<10;$j++){ for($k=0;$k<count($b[$j]);$k++){ if($b[$j][$k]!=0) $arr[$m++] = $b[$j][$k];//将容器中的数按序取出,进行下一次排序 } } $b = array();//再给b附新值前要清空数组中原有的数据 } for($i=0;$i<count($arr);$i++) { $thisNum = getN($arr[$i],$M); if($thisNum!=0) $flag = 1; $b[$thisNum][] = $arr[$i];//将数组中的数放入容器中 } } print_r($arr); //var_dump($b); } /**基数排序**结束**/ paixu(array(65,3,45,6,7,8,31,100,1000,1234)) ?>
実行結果:
コードは次のとおりです:Array ( [0] => 3 [1] => 6 [2] => 7 [3] => 8 [4] => 45 [7] => 1000
基数ソートは、重複する数値を検索したり、間隔の数値を検索したりするためにも使用できます。
コードは重要ではありません (コードはまだ改善する必要があります)、アイデアが鍵です
関連する推奨事項:
以上がPHPの基数ソート方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

CakePHP はオープンソースの MVC フレームワークです。これにより、アプリケーションの開発、展開、保守がはるかに簡単になります。 CakePHP には、最も一般的なタスクの過負荷を軽減するためのライブラリが多数あります。

文字列は、文字、数字、シンボルを含む一連の文字です。このチュートリアルでは、さまざまな方法を使用してPHPの特定の文字列内の母音の数を計算する方法を学びます。英語の母音は、a、e、i、o、u、そしてそれらは大文字または小文字である可能性があります。 母音とは何ですか? 母音は、特定の発音を表すアルファベットのある文字です。大文字と小文字など、英語には5つの母音があります。 a、e、i、o、u 例1 入力:string = "tutorialspoint" 出力:6 説明する 文字列「TutorialSpoint」の母音は、u、o、i、a、o、iです。合計で6元があります

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。
