이전 글 "PHP가 20세기에 모든 윤년을 출력하는 방법"에서는 윤년의 특성을 이용하여 윤년을 결정하는 일반적인 알고리즘을 소개했습니다. 이번에는 PHP를 사용하여 세 자리 숫자가 회문 번호인지 확인하는 방법과 세 자리 회문 번호를 모두 출력하는 방법을 소개합니다. 관심 있는 친구들은 이에 대해 배울 수 있습니다~
먼저 이해해야 합니다무엇입니까? 회문 번호?
Palindrome은 (0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 22, 121, 656, 757, 12321, 5264625 등).
그럼 세 자리 숫자 i
가 주어지면 세 자리 숫자가 회문인지 여부를 어떻게 판단할 수 있나요? i
,如何判断这个三位数是不是回文数呢?
思想:
我们可以将这个三位数(例如121)的个位、十位、百位上的数,单独取出来,即g、s、b。
然后将 g*100、s*10,在和百位数b相加:g*100+s*10+b
;这样会得到一个新的三位数hws
。
使用if语句判断 i
是否等于 hws
,即可判断出该三位数 i
是不是回文数了。
因此我们可以给出判断一个三位数是不是回文数的方法
<?php header("Content-type:text/html;charset=utf-8"); $i=121; $b= intval($i/100); $s= ($i/10)%10; $g= $i%10; $hws=$g*100+$s*10+$b; if($i==$g*100+$s*10+$b){ echo $i."是回文数"; } else{ echo $i."不是回文数"; } ?>
输出结果为:
121是回文数
既然知道了如何判断一个三位数是不是回文数了,下面增加难度:我们来输出全部三位回文数!
分析:输出全部三位回文数,那就是输出100~999内的回文数;因此我们可以使用for循环来限定范围
<?php header("Content-type:text/html;charset=utf-8"); $num=0; for($i=100;$i<1000;$i++){ $b= intval($i/100); $s= ($i/10)%10; $g= $i%10; $hws=$g*100+$s*10+$b; if($i==$g*100+$s*10+$b){ echo $i." "; $num++; } } echo "<br><br>三位回文数共有".$num."个"; ?>
输出结果为:
可以看出,我们在for循环的循环体中,使用一个计数器$num
생각: 이 세 자리 숫자(예: 121)의 일, 십, 백 자리를 구분할 수 있으니 꺼내서, 즉, g, s, b.
g*100+s*10+b
그러면 새로운 3-가 생성됩니다. 숫자 hws
. 🎜i
가 hws
와 같은지 확인하면 세 자리 숫자 i가 같은지 확인할 수 있습니다.
는 회문에 번호가 매겨져 있습니다. 🎜$num
를 사용하여 세 자리 회문 번호가 출력될 때마다 1씩 증가하므로 100에서 999 사이에 회문이 몇 개 있는지 계산할 수 있습니다. . 🎜🎜그렇습니다. 더 알고 싶다면 여기를 클릭하세요. → →🎜php 비디오 튜토리얼🎜🎜위 내용은 PHP 프로그램을 통해 세 자리 회문 숫자를 모두 출력하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!