php四种基础算法代码实例_PHP教程
php四种基础算法:冒泡,选择,插入和快速排序法
许多人都说 算法是程序的核心,一个程序的好于差,关键是这个程序算法的优劣。作为一个初级phper,虽然很少接触到算法方面的东西 。但是对于冒泡排序,插入排序,选择排序,快速排序四种基本算法,我想还是要掌握的。下面是我按自己的理解,将四个方法分析一遍。
需求:分别用 冒泡排序法,快速排序法,选择排序法,插入排序法将下面数组中 的值按照从小到的顺序进行排序。
$arr(1,43,54,62,21,66,32,78,36,76,39);
1. 冒泡排序法
* 思路分析:法如其名,就是像冒泡一样,每次从数组当中 冒一个最大的数出来。
* 比如:2,4,1 // 第一次 冒出的泡是4
* 2,1,4 // 第二次 冒出的泡是 2
* 1,2,4 // 最后就变成这样
* 代码实现:
$arr=array(1,43,54,62,21,66,32,78,36,76,39);
function getpao($arr)
{
$len=count($arr);
//设置一个空数组 用来接收冒出来的泡
//该层循环控制 需要冒泡的轮数
for($i=1;$i { //该层循环用来控制每轮 冒出一个数 需要比较的次数
for($k=0;$k {
if($arr[$k]>$arr[$k+1])
{
$tmp=$arr[$k+1];
$arr[$k+1]=$arr[$k];
$arr[$k]=$tmp;
}
}
}
return $arr;
}
2. 选择排序法:
选择排序法思路: 每次选择一个相应的元素,然后将其放到指定的位置
function select_sort($arr) {
//实现思路 双重循环完成,外层控制轮数,当前的最小值。内层 控制的比较次数
//$i 当前最小值的位置, 需要参与比较的元素
for($i=0, $len=count($arr); $i //先假设最小的值的位置
$p = $i;
//$j 当前都需要和哪些元素比较,$i 后边的。
for($j=$i+1; $j //$arr[$p] 是 当前已知的最小值
if($arr[$p] > $arr[$j]) {
//比较,发现更小的,记录下最小值的位置;并且在下次比较时,
// 应该采用已知的最小值进行比较。
$p = $j;
}
}
//已经确定了当前的最小值的位置,保存到$p中。
//如果发现 最小值的位置与当前假设的位置$i不同,则位置互换即可
if($p != $i) {
$tmp = $arr[$p];
$arr[$p] = $arr[$i];
$arr[$i] = $tmp;
}
}
//返回最终结果
return $arr;
}
3.插入排序法
插入排序法思路:将要排序的元素插入到已经 假定排序号的数组的指定位置。
function insert_sort($arr) {
//区分 哪部分是已经排序好的
//哪部分是没有排序的
//找到其中一个需要排序的元素
//这个元素 就是从第二个元素开始,到最后一个元素都是这个需要排序的元素
//利用循环就可以标志出来
//i循环控制 每次需要插入的元素,一旦需要插入的元素控制好了,
//间接已经将数组分成了2部分,下标小于当前的(左边的),是排序好的序列
for($i=1, $len=count($arr); $i //获得当前需要比较的元素值。
$tmp = $arr[$i];
//内层循环控制 比较 并 插入
for($j=$i-1;$j>=0;$j--) {
//$arr[$i];//需要插入的元素; $arr[$j];//需要比较的元素
if($tmp //发现插入的元素要小,交换位置
//将后边的元素与前面的元素互换
$arr[$j+1] = $arr[$j];
//将前面的数设置为 当前需要交换的数
$arr[$j] = $tmp;
} else {
//如果碰到不需要移动的元素
//由于是已经排序好是数组,则前面的就不需要再次比较了。
break;
}
}
}
//将这个元素 插入到已经排序好的序列内。
//返回
return $arr;
}
4.快速排序法
function quick_sort($arr) {
//先判断是否需要继续进行
$length = count($arr);
if($length return $arr;
}
//如果没有返回,说明数组内的元素个数 多余1个,需要排序
//选择一个标尺
//选择第一个元素
$base_num = $arr[0];
//遍历 除了标尺外的所有元素,按照大小关系放入两个数组内
//初始化两个数组
$left_array = array();//小于标尺的
$right_array = array();//大于标尺的
for($i=1; $i if($base_num > $arr[$i]) {
//放入左边数组
$left_array[] = $arr[$i];
} else {
//放入右边
$right_array[] = $arr[$i];
}
}
//再分别对 左边 和 右边的数组进行相同的排序处理方式
//递归调用这个函数,并记录结果
$left_array = quick_sort($left_array);
$right_array = quick_sort($right_array);
//合并左边 标尺 右边
return array_merge($left_array, array($base_num), $right_array);
}

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen











Bei der PHP-Programmierung sind Algorithmen ein integraler Bestandteil. Die Beherrschung gängiger Algorithmen kann nicht nur die Codeeffizienz verbessern, sondern auch Hilfe beim späteren Programmdesign bieten. Die folgenden sind gängige Algorithmen in der PHP-Programmierung: Sortieralgorithmus Unter Sortieralgorithmus versteht man das Anordnen einer Datenmenge in einer geordneten Reihenfolge nach bestimmten Regeln. Zu den in der PHP-Programmierung häufig verwendeten Sortieralgorithmen gehören Blasensortierung, Einfügungssortierung, Auswahlsortierung, Schnellsortierung usw. Unter diesen ist die schnelle Sortierung der Sortieralgorithmus mit der geringsten zeitlichen Komplexität und eignet sich für die Verarbeitung großer Datenmengen. Suchalgorithmus Suchalgorithmus

PHP ist eine sehr beliebte Programmiersprache, die verschiedene Datentypen und Algorithmen unterstützt, von denen Array-Sortierung und Suchalgorithmen grundlegende und wichtige Bestandteile sind. In diesem Artikel werden häufig verwendete Array-Sortier- und Suchalgorithmen in PHP sowie deren Anwendungsszenarien und Effizienzanalysen vorgestellt. 1. Array-Sortierung PHP bietet eine Vielzahl von Array-Sortiermethoden, einschließlich Blasensortierung, Einfügungssortierung, Auswahlsortierung, Schnellsortierung, Zusammenführungssortierung usw. Im Folgenden finden Sie eine Einführung und einen Beispielcode für mehrere häufig verwendete Algorithmen: Bubble Sort (BubbleSort)

PHP ist eine in der Webentwicklung weit verbreitete Skriptsprache und wird beim Erstellen dynamischer Websites immer besser. In der Webentwicklung sind Datenstrukturen und Algorithmen nicht weniger wichtig als andere Programmierkategorien und ihr Einfluss auf die Effizienz der Programmausführung ist besonders groß. Insbesondere in Szenarien mit großer Datenspeicherung und -verarbeitung oder hohen Anforderungen an die Programmleistung sind Datenstrukturen und Algorithmen zu einem nicht zu vernachlässigenden Bestandteil geworden. In diesem Artikel werden hauptsächlich einige häufig verwendete Datenstrukturen und Algorithmen in PHP vorgestellt. 1. Datenstruktur-Array PHP-Array ist ein sehr verbreitetes Array

Mit der Popularität des Internets und der kontinuierlichen Erweiterung der Anwendungen hat die Entwicklung von Programmiersprachen immer mehr an Bedeutung gewonnen. Als sehr beliebte Programmiersprache entwickelt sich auch PHP ständig weiter. Beim Programmieren mit PHP stehen PHP-Entwickler möglicherweise vor der Notwendigkeit, einige Kenntnisse darzustellen und automatisch Algorithmen zu generieren. Wie kann man also Wissen darstellen und automatisch Algorithmen in PHP generieren? Dieser Artikel wird dies weiter unten besprechen. 1. Wissensrepräsentation Wissensrepräsentation ist ein sehr wichtiges Thema im Bereich der künstlichen Intelligenz. Wissen

Analyse des PHP-Algorithmus: Wie verwende ich den binären Suchalgorithmus, um Elemente in einem geordneten Array schnell zu finden? Übersicht: Der binäre Suchalgorithmus ist ein effizienter Suchalgorithmus, der zum Auffinden bestimmter Elemente in einem geordneten Array geeignet ist. In diesem Artikel wird das Prinzip des binären Suchalgorithmus ausführlich vorgestellt und PHP-Codebeispiele gegeben. Prinzip: Der binäre Suchalgorithmus findet das Zielelement schnell, indem er den Suchbereich wiederholt um die Hälfte reduziert. Der Vorgang ist wie folgt: Grenzen Sie zunächst den Suchbereich auf den Anfang und das Ende des Arrays ein. Berechnen Sie dann den Index des mittleren Elements und vergleichen Sie ihn mit dem Zielelement.

Analyse des PHP-Algorithmus: Wie kann ein dynamischer Programmieralgorithmus verwendet werden, um das 0-1-Rucksackproblem zu lösen? Einleitung: Dynamische Programmierung ist eine algorithmische Idee, die häufig zur Lösung von Optimierungsproblemen verwendet wird. In der Programmentwicklung ist das 0-1-Rucksackproblem ein klassisches Anwendungsszenario der dynamischen Programmierung. In diesem Artikel wird erläutert, wie Sie mithilfe von PHP einen dynamischen Programmieralgorithmus zur Lösung des 0-1-Rucksackproblems schreiben und spezifische Codebeispiele bereitstellen. Was ist das 0:1-Rucksackproblem? Das 0-1-Rucksackproblem ist ein klassisches kombinatorisches Optimierungsproblem. Das Problem stellt sich wie folgt dar: Es gibt einen Rucksack mit einem Fassungsvermögen von C. Es gibt n Objekte

Vertiefendes Verständnis der Kernalgorithmen von PHP und Vue in der Brain-Mapping-Funktion Einführung: Im modernen Internetzeitalter verwenden wir häufig eine Vielzahl von Anwendungen, die uns bei der Organisation und Verwaltung von Informationen helfen. Brain Mapping ist eine gängige und praktische Methode zur Organisation von Informationen, mit der komplexe Denkprozesse grafisch dargestellt werden können. In diesem Artikel konzentrieren wir uns auf die Kernalgorithmen von PHP und Vue in der Brain-Mapping-Funktion und geben Codebeispiele. 1. Merkmale von Mind Maps Mind Maps sind eine Art Brain Map, die ein zentrales Thema als Kern hat und Informationen zu diesem Thema in einer Baumstruktur anzeigt.

PHP ist eine weit verbreitete Entwicklungssprache, die häufig für die Entwicklung von Webanwendungen verwendet wird. Webanwendungen müssen jedoch häufig große Datenmengen verarbeiten, einschließlich Datenverarbeitung, Speicherung und Abfrage usw. Daher ist die Anwendung von Algorithmen und Datenstrukturen in PHP eine sehr wichtige Technologie. Ein Algorithmus ist eine allgemeine Methode, die in der Computerprogrammierung zur Lösung von Problemen verwendet wird. Beim Programmieren lösen wir Probleme, indem wir Algorithmen entwerfen und implementieren, um die Effizienz, Wartbarkeit und Skalierbarkeit unserer Programme zu verbessern. Zu den häufig verwendeten Algorithmen gehören Sortieren, Suchen, Teilen und Erobern, Greedy usw.
