如果数字或字符串分别反转数字或字母后仍保持相同,则称其为回文结构。那么如何检查数字和字符串是否为回文结构?下面本篇文章就来带大家了解一下在PHP中检查数字和字符串是否为回文结构的方法,希望对大家有所帮助。
一、检查回文数
这里我们简单地使用迭代方法来检查回文数。每个数字在迭代中被提取并形成相反的数字,最后,检查它是否与原始数字相同。
下面我们通过代码示例来看看实现方法。
<?php header("content-type:text/html;charset=utf-8"); function Palindrome($number){ $temp = $number; $new = 0; while (floor($temp)) { $d = $temp % 10; $new = $new * 10 + $d; $temp = $temp/10; } if ($new == $number){ return 1; } else{ return 0; } } $original = 1441; if (Palindrome($original)){ echo $original."是回文数"; } else { echo $original."不是回文数"; } ?>
输出:
二、检查回文字符串
方法1:使用strrev()
strrev()方法在PHP中用于反转字符串。我们可以简单地使用此方法来反转字符串并将其与未反转前的字符串进行匹配。如果匹配成功,则字符串是回文,否则不是回文。
下面我们通过代码示例来看看实现方法。
<?php header("content-type:text/html;charset=utf-8"); function Palindrome($string){ if (strrev($string) == $string){ return 1; } else{ return 0; } } $original = "hgbgbgh"; if (Palindrome($original)){ echo $original."是回文字符串"; } else { echo $original."不是回文字符串"; } ?>
输出:
方法2:使用substr()的递归方式
substr()方法用于返回字符串的一部分,称为子字符串。使用该substr()方法,可以通过一种递归方式来检查字符串是否为回文。
注:substr()方法中,不会形成新字符串,并且在每次递归调用中都会修改原始字符串。
原理:在每次递归调用期间,让第一个字符与字符串的最后一个字符进行匹配,如果匹配,则在下一次调用期间丢弃这两个字符。这一直持续到字符串的长度减少到0或1,则该字符串为回文。
下面我们通过代码示例来看看实现方法。
<?php header("content-type:text/html;charset=utf-8"); function Palindrome($string){ //结束递归 if ((strlen($string) == 1) || (strlen($string) == 0)){ echo "回文字符串"; } else{ // 第一个字符与最后一个字符比较 if (substr($string,0,1) == substr($string,(strlen($string) - 1),1)){ // 选中的字母将被丢弃并传递给下一个字符串 return Palindrome(substr($string,1,strlen($string) -2)); } else{ echo "不是回文字符串"; } } } $string = "MALAYALAM"; Palindrome($string); ?>
输出:
回文字符串
示例说明:
在上面的例子中,检查字符串“MALAYALAM”是否为回文,让我们看看如何工作的。
在第一步中,两者都是M,比较结束。由于它匹配,它们都被丢弃;下一个要传递的字符串是“ALAYALA”。同样,两个A在两端都匹配,因此要传递的下一个字符串是“LAYAL”。这种情况一直持续到只剩下“Y”。因此字符串“MALAYALAM”是回文的。
相关视频教程推荐:《PHP教程》
以上就是本篇文章的全部内容,希望能对大家的学习有所帮助。更多精彩内容大家可以关注php中文网相关教程栏目!!!
Atas ialah kandungan terperinci PHP如何检查数字和字符串是否为回文结构?(代码示例). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!