关于本站
“最难不过坚持”
本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作
有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339
2655
39
分类目录
最新评论
- https://jueru.net/
-
- :weixiao:
-
- :shuijiao: :weiqu: :zhenbang: :leng:
-
- :yiwen: :yiwen: :yiwen: :yiwen:
-
- 这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
-
文章标签更多
如果数字或字符串分别反转数字或字母后仍保持相同,则称其为回文结构。
那么如何检查数字和字符串是否为回文结构?
一、检查回文数
这里我们简单地使用迭代方法来检查回文数。每个数字在迭代中被提取并形成相反的数字,最后,检查它是否与原始数字相同。
下面我们通过代码示例来看看实现方法。
<?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 . "不是回文数"; } // 输出:1441是回文数 ?>二、检查回文字符串
方法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 . "不是回文字符串"; } // hgbgbgh是回文字符串 ?>方法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 // 检查字符串是否是回文 function huiwen($str){ $isHuiwen = true; $len = strlen($str); for($i = 0; $i < ceil($len/2); $i++){ if(substr($str, $i, 1) != substr($str, -($i+1), 1)){ $isHuiwen = false; break; } } return $isHuiwen; } $str = 'MALAYALAM'; if(huiwen($str)){ echo '是回文'; }else{ echo '不是回文'; } ?>
赏
相关推荐
php实现ZIP压缩文件解压缩,中文乱码解决方法(重要)
直接上代码,具体代码里面都有注释。直接中文压缩文件解压到中文文件夹。
<?php
// 需开启配置 php_zip.dll
// phpinfo();
header("Content-type:text/html;charset=utf-8");
/*
* $filename 被解压文件名
* $path 解压...
openssl_private_decrypt解密失败
复制别人的解密程序,原程序可以解密,复制过来就不可以
一步步尝试发现,秘钥换行符有区别,
原秘钥有换行符,复制过来不知道什么时候把换行符清空了,成了一行字符串了。
评论加载中...