php function用法如何递归及return和echo区别_PHP教程
//模拟sql数据
$array = array(0=>'apple',1=>'banana',2=>'cat',3=>'dog',4=>'egg','5'=>'father');
//function 用法1
//arr 是传入的数据 $con 是条件
function f_1($arr,$con){
//这里的 array 是这个函数内私有的,不会和出面的array冲突
//所以,外地面的 array不里直接在内面用,里面的array也不能直接外面用
//先实例一个array
$array = array();
//for foreach while 用法都类似,具体baidu
foreach ($arr as $key => $value) {
//如果循环出来的 value 等于 con 的话,就把他加入到数组
if ($value == $con) {
//数组和变量的区别在于加了个 []
$array[] = array($key => $value);
}
}
//循环得到结果后 返回数组。所以,这个函数就是一个数组
return $array;
//return 执行后就终断了,无论后面还有什么代码 都不会被执行
//return可以看做是一个函数结束的地方
}
//function 用法2
//$con 可以是数组
function f_2($arr,$con){
//先实例一个变量
$code = '
- ';
- '.$value.' ';
foreach ($arr as $key => $value) {
//里面的for循环 是 循环出con内容
foreach ($con as $value2) {
// .= 往后添加更多 连续定义变量
// 如果第一层数据循环出来的值,和第二层条件循环出现的值相同,添加到 变量里
//多个for循环来过滤数据也称为 递归
if ($value == $value2) {
$code .= '
}
}
}
$code .= '
//循环得到结果后 返回变量。所以,这个函数就是一个字符串
return $code;
}
//function 用法3
//在函数里 echo 和 return 有什么区别 看执行结果
function f_3($arr,$con){
//先实例一个变量
echo '
- ';
- '.$value.' ';
foreach ($arr as $key => $value) {
//里面的for循环 是 循环出con内容
foreach ($con as $value2) {
// .= 往后添加更多 连续定义变量
// 如果第一层数据循环出来的值,和第二层条件循环出现的值相同,添加到 变量里
//多个for循环 去过滤数据也称为 递归
if ($value == $value2) {
echo '
}
}
}
echo '
}
?>
f_1 output start
//因为 f_1 是一个数组,我们可以打印出来
print_r(f_1($array,'banana'));
?>
f_1 output end
f_2 output start
//f_2 是变量
$con = array('apple','father');
echo f_2($array,$con);
?>
f_2 output end
f_2 output start
//f_3 已经在函数里面echo 了,所以在函数执行时不用echo
$con = array('apple','father');
f_3($array,$con);
?>
f_2 output end

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

La profondeur de récursion des fonctions C++ est limitée et le dépassement de cette limite entraînera une erreur de débordement de pile. La valeur limite varie selon les systèmes et les compilateurs, mais se situe généralement entre 1 000 et 10 000. Les solutions incluent : 1. Optimisation de la récursion de queue ; 2. Appel de queue ; 3. Implémentation itérative ;

Oui, les expressions C++ Lambda peuvent prendre en charge la récursivité à l'aide de std::function : utilisez std::function pour capturer une référence à une expression Lambda. Avec une référence capturée, une expression Lambda peut s'appeler de manière récursive.

L'utilisation de return en langage C est la suivante : 1. Pour les fonctions dont le type de valeur de retour est void, vous pouvez utiliser l'instruction return pour terminer l'exécution de la fonction plus tôt. 2. Pour les fonctions dont le type de valeur de retour n'est pas void, la fonction de ; l'instruction return sert à terminer l'exécution de la fonction.Le résultat est renvoyé à l'appelant ;3. Terminer l'exécution de la fonction plus tôt que prévu.À l'intérieur de la fonction, nous pouvons utiliser l'instruction return pour terminer l'exécution de la fonction plus tôt. si la fonction ne renvoie pas de valeur.

Nous prenons le tableau d'entiers Arr[] en entrée. Le but est de trouver les éléments les plus grands et les plus petits d’un tableau en utilisant une méthode récursive. Puisque nous utilisons la récursion, nous allons parcourir l'ensemble du tableau jusqu'à ce que nous atteignions length = 1, puis retourner A[0], qui constitue le cas de base. Sinon, l'élément actuel est comparé à la valeur minimale ou maximale actuelle et sa valeur est mise à jour de manière récursive pour les éléments suivants. Examinons différents scénarios d'entrée et de sortie pour cela −Input −Arr={12,67,99,76,32}; Output −Valeur maximale dans le tableau : 99 Explication &mi ;

Étant donné deux chaînes str_1 et str_2. Le but est de compter le nombre d'occurrences de la sous-chaîne str2 dans la chaîne str1 en utilisant une procédure récursive. Une fonction récursive est une fonction qui s'appelle dans sa définition. Si str1 est "Je sais que vous savez que je sais" et str2 est "savoir", le nombre d'occurrences est de -3 Comprenons à travers des exemples. Par exemple, entrez str1="TPisTPareTPamTP", str2="TP" ; sortie Countofoccurrencesofasubstringrecursi.

L'algorithme récursif résout des problèmes structurés grâce à l'auto-appel de fonctions. L'avantage est qu'il est simple et facile à comprendre, mais l'inconvénient est qu'il est moins efficace et peut provoquer un débordement de pile. L'algorithme non récursif évite la récursion en gérant explicitement le. structure de données de pile. L'avantage est qu'il est plus efficace et évite le débordement de pile, l'inconvénient est que le code peut être plus complexe. Le choix du récursif ou du non récursif dépend du problème et des contraintes spécifiques de la mise en œuvre.

À l'ère actuelle de développement technologique rapide, les langages de programmation poussent comme des champignons après la pluie. L'un des langages qui a beaucoup retenu l'attention est le langage Go, apprécié par de nombreux développeurs pour sa simplicité, son efficacité, sa sécurité de concurrence et d'autres fonctionnalités. Le langage Go est connu pour son écosystème solide avec de nombreux excellents projets open source. Cet article présentera cinq projets open source sélectionnés en langage Go et amènera les lecteurs à explorer le monde des projets open source en langage Go. KubernetesKubernetes est un moteur d'orchestration de conteneurs open source pour l'automatisation

Une fonction récursive est une technique qui s'appelle à plusieurs reprises pour résoudre un problème de traitement de chaînes. Cela nécessite une condition de terminaison pour empêcher une récursion infinie. La récursivité est largement utilisée dans des opérations telles que l'inversion de chaînes et la vérification du palindrome.
