Maison >développement back-end >tutoriel php >Le moyen le plus efficace de trouver des éléments spécifiques à l'aide d'un tableau PHP

Le moyen le plus efficace de trouver des éléments spécifiques à l'aide d'un tableau PHP

PHPz
PHPzoriginal
2024-05-04 15:51:01628parcourir

Les moyens efficaces de trouver des éléments spécifiques à l'aide de tableaux PHP incluent la recherche séquentielle et la recherche binaire. La recherche séquentielle fonctionne sur n'importe quel tableau, tandis que la recherche binaire ne fonctionne que sur les tableaux triés. Les étapes d'énumération du numéro de série sont les suivantes : Recherche séquentielle : parcourez le tableau et comparez les éléments un par un jusqu'à ce que l'élément cible soit trouvé ou que la fin du tableau soit atteinte. Recherche binaire : réduisez continuellement la plage de recherche de moitié jusqu'à ce que l'élément cible soit trouvé ou que la plage de recherche soit réduite à un seul élément.

Le moyen le plus efficace de trouver des éléments spécifiques à laide dun tableau PHP

Un moyen efficace de trouver des éléments spécifiques à l'aide de tableaux PHP

La recherche d'éléments à l'aide de tableaux est une tâche courante en PHP. Il existe plusieurs façons d’y parvenir, chacune avec ses propres avantages et inconvénients. Cet article présentera certaines des méthodes les plus efficaces et fournira des cas pratiques pour votre référence.

1. Recherche séquentielle

La recherche séquentielle est la méthode la plus simple. Il parcourt le tableau, comparant élément par élément jusqu'à ce que l'élément cible soit trouvé ou que la fin du tableau soit atteinte.

function sequentialSearch($arr, $target) {
    for ($i = 0; $i < count($arr); $i++) {
        if ($arr[$i] == $target) {
            return $i;  // 返回元素的下标
        }
    }
    return -1;  // 如果未找到,返回 -1
}

2. Recherche binaire

La recherche binaire ne fonctionne que sur les tableaux triés. Il améliore l’efficacité en réduisant continuellement la portée de la recherche de moitié.

function binarySearch($arr, $target) {
    $low = 0;
    $high = count($arr) - 1;

    while ($low <= $high) {
        $mid = (int) (($low + $high) / 2);
        if ($arr[$mid] == $target) {
            return $mid;
        } else if ($arr[$mid] < $target) {
            $low = $mid + 1;
        } else {
            $high = $mid - 1;
        }
    }
    return -1;
}

Cas pratique

Supposons qu'il existe un tableau contenant les notes des élèves :

$scores = [85, 90, 75, 95, 80];

Pour trouver les notes d'un certain élève, vous pouvez utiliser l'exemple de code suivant :

$targetScore = 90;
$index = sequentialSearch($scores, $targetScore);
if ($index != -1) {
    echo "找到了成绩为 $targetScore 的学生,下标为 $index。";
} else {
    echo "找不到成绩为 $targetScore 的学生。";
}

Pour les tableaux triés, vous pouvez utiliser ce qui suit code pour effectuer une recherche binaire :

$targetScore = 90;
$index = binarySearch($scores, $targetScore);
if ($index != -1) {
    echo "找到了成绩为 $targetScore 的学生,下标为 $index。";
} else {
    echo "找不到成绩为 $targetScore 的学生。";
}

En utilisant la méthode ci-dessus, vous pouvez trouver rapidement et efficacement des éléments spécifiques dans des tableaux PHP, améliorant ainsi les performances de votre code.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Articles Liés

Voir plus