Maison >développement back-end >tutoriel php >Boucle PHP Learning Ten : déterminer le nombre de jonquilles et imprimer le nombre de toutes les jonquilles
Dans l'article précédent "PHP Loop Learning 9 : Obtention du plus grand commun diviseur entre deux nombres donnés", nous vous avons présenté comment utiliser l'instruction de boucle while pour trouver le plus grand commun diviseur entre deux entiers donnés dans le programme PHP Number. , continuons à découvrir les boucles PHP~
Cet article vous montre principalement, étant donné un entier à trois chiffres, comment déterminer si le nombre est un nombre de narcisse ? Ensuite, comment afficher le nombre total de jonquilles.
Tout d’abord, jetons un coup d’oeilQuel est le numéro du narcisse ?
Le nombre jonquille est un nombre à 3 chiffres où la somme des 3èmes puissances des chiffres de chaque chiffre est égale à elle-même (par exemple : 1^3 + 5^3+ 3^3 = 153).
Voyons d'abord comment déterminer si un nombre à trois chiffres donné est un nombre narcisse ?
Analyse des idées :
D'après ce qui précède nous savons : si un nombre $num
est un nombre jonquille, alors il doit satisfaire : la troisième puissance du chiffre des unités + le chiffre des dizaines 3ème puissance + 3ème puissance des centaines = $num lui-même
$num
要是水仙花数,那么它要满足: 个位的3次方+十位的3次方+百位的3次方= $num本身
那么我们可以先分解$num
,得到个位$g、
十位$s
、百位$b
然后判断 $g^3 + $^3 +$b^3
是不是等于$num
下面看看实现代码:
<?php header("Content-type:text/html;charset=utf-8"); function is_narcissistic ( $num ){ $b= intval($num/100); $s= ($num/10)%10; $g= $num%10; // if($b*$b*$b+$s*$s*$s+$g*$g*$g==$num){ 等价于 if(pow($b,3)+pow($s,3)+pow($g,3)==$num){ echo $num."是水仙花数<br>"; }else{ echo $num."不是水仙花数<br>"; } } is_narcissistic(153); is_narcissistic(152); ?>
输出结果:
上例中pow($b,3)
和$b*$b*$b
是等价的,都可以计算$b的三次方($b^3
)。pow(x,y)
函数可以返回 x 的 y 次方,即x^y
。
我们知道水仙花数是一个 3 位数,则它是有定额的,那么如何计算并输出所有的水仙花数呢?这就需要使用循环了。
可以利用for循环来限定范围在100~1000之间,写法:
<?php header("Content-type:text/html;charset=utf-8"); $i=0; for ( $num = 100; $num < 1000; $num++){ $b= intval($num/100); $s= ($num/10)%10; $g= $num%10; if(pow($b,3)+pow($s,3)+pow($g,3)==$num){ echo $num."<br>"; $i++; } } echo "水仙花数共有 $i 个"; ?>
看看输出结果:
除了上面计算并输出所有水仙花数的方法,还可以使用3个for循环遍历每一位来输出所有水仙花数:
<?php header("Content-type:text/html;charset=utf-8"); $i=0; for($q=1;$q<=9;$q++){ for($w=0;$w<=9;$w++){ for($e=0;$e<=9;$e++){ if($q*$q*$q + $w*$w*$w + $e*$e*$e == 100*$q + 10*$w + $e){ echo "$q $w $e "."<p>"; $i++; } } } } echo "水仙花数共有 $i 个"; ?>
看看输出结果:
可以看出,输出结果是一样的。
可以看出,我们在for循环的循环体中,使用一个计数器$num
$num
pour obtenir le chiffre des unités $g,
dizaines chiffre $s
, les centaines placent $b
puis déterminent si $g^3 + $^3 +$b^3
est égal à $num
pow($b,3)
et $ b*$b*$b sont équivalents et peuvent calculer le cube de $b (<code>$b^3
). La fonction pow(x,y)
peut renvoyer x élevé à la puissance y, c'est-à-dire x^y
. 🎜🎜Nous savons que le numéro de jonquille est un nombre à 3 chiffres, il a donc un quota. Alors, comment calculer et afficher tous les numéros de jonquille ? Cela nécessite l'utilisation de boucles. 🎜🎜Vous pouvez utiliser une boucle for pour limiter la plage entre 100 et 1000. Méthode d'écriture : 🎜rrreee🎜Regardez le résultat de sortie : 🎜🎜🎜🎜En plus de la méthode ci-dessus de calcul et de sortie de tous les nombres de jonquilles, vous pouvez également utiliser 3 pour les boucles pour parcourir chaque chiffre pour afficher le nombre de toutes les jonquilles : 🎜rrreee🎜Regardez la sortie : 🎜🎜🎜🎜On peut voir que les résultats de sortie sont les mêmes. 🎜🎜On peut voir que nous utilisons un compteur $num
dans le corps de la boucle for. Après chaque fois qu'un nombre palindrome à trois chiffres est généré, il s'incrémente de 1, de sorte que 100 puisse être obtenu. être compté. Combien y a-t-il de palindromes dans ~ 999 ? 🎜🎜D'accord, c'est tout. Si vous voulez savoir autre chose, vous pouvez cliquer ici. → →🎜Tutoriel vidéo php🎜🎜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!