这篇文章将为大家详细讲解有关PHP检查数字和字符串是否为回文结构的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
如果数字或字符串分别反转数字或字母后仍保持相同,则称其为回文结构。那么如何检查数字和字符串是否为回文结构?下面本篇文章就来带大家了解一下在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检查数字和字符串是否为回文结构的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。