请讲解该排序
请详细讲解一下递归的过程
function al_merge($arrA,$arrB){
<code> $arrC = array(); while(count($arrA)&&count($arrB)){ $arrC[]=$arrA['0']</code>
回复内容:
请详细讲解一下递归的过程
function al_merge($arrA,$arrB){
<code> $arrC = array(); while(count($arrA)&&count($arrB)){ $arrC[]=$arrA['0']</code>
唉各位downvote的大真的也不要太急躁. 这样说吧, 题主桑你主要有3个问题:
- 看到你profile里的很多问题其实只需要仔细调试一下能解决, 不必特意提一个问题.
- 没有善用搜索引擎. 程序员都很喜欢分享知识, 所以无论是讲解什么语法,算法还是库的博客都非常多.
- 这种问题最好在sf的子站101里面提问. 说到sf, 建议善用一下markdown排版.
回到这个问题上面, 这种排序叫做归并排序, 算法思路叫分治法. 这个你在搜索引擎上随便动动手指就可以找到大量资料.
- 首先是将
$arr
劈开成,两个数组$left_arr
,$right_arr
. - 然后将这些数组都分别再调用一次
al_merge_sort()
, 在这不停地调用过程中, 整个数组被不停地劈开, 再劈开. - 这么劈下去始终有一天数组会只剩下一个元素的. 一个元素就无需排序了, 直接返回.
- 这时, 我们希望从
al_merge_sort
返回的都是已经排好序的数组了. - 然后调用
al_merge()
, 让它从小到大将两个已经排好序的数组从小到大混在一起. - 这样, 形成了一个新的排好序的数组, 好, 返回. 返回上去之后重复第四步.
- 一直冒到最顶, 也就是你的代码最后一行所调用, 也是一个排好序的数组了.

ホット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 は、

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

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