使用PHP实现水仙花数及各种特殊有趣数的输出

尊敬的读者,见文好。

本文包含以下内容:

1,为什么要写这篇文章!

2,具体的方案及代码实现!

3,你可能遇到的问题!

4,文末本文测试用源码网盘地址!


特殊说明:

本文使用的语言是PHP;

本文运行的环境是:Apache2.4, PHP5.6


第一部分:为什么要写这篇文章!

因为经常会有人问到如何输出“水仙花数”,经查阅百度百科,不仅仅有“水仙花数”,还有很多有意思的数字!尝试写出了可以生成这些有趣数字的一个函数!有两种思路!

注:经过压测,第一种思路的执行效率要高于第二种!可见对于数据的处理效率要远远高于对于文字的处理的!

第二部分:具体的方案及代码实现!

第一种方案:

使用求余数加上php中的地板函数floor()来获取数字的每一位并进行数学运算!

/**
     * @author Lizisir <[email protected]>
     * 可以计算数字中具有特殊含义的数字
     * @param  int $number 数字的位数
     * @return null
     */
    function specialNumber( $number )
    {
        $numberNameList = [
                ‘独身数‘,
                ‘没有‘,
                ‘水仙花数‘,
                ‘四叶玫瑰数‘,
                ‘五角星数‘,
                ‘六合数‘,
                ‘北斗七星数‘,
                ‘八仙数‘,
                ‘九九重阳数‘,
                ‘十全十美数‘
            ];
        // 输出对应的特殊数字的名称 例如:水仙花数
        echo $numberNameList[ $number-1 ].":<br>";

        $start = pow( 10, $number-1 ) + 1;
        $end = pow( 10, $number );

        for ( $i = $start; $i < $end; ++ $i ) 
        { 
            // 接受数字每位的n次幂的和
            $sum = 0;
            
            // 目标数字
            $aimNumber = $i;    

            // 计算数字每位的n次幂的和
            while( $aimNumber != 0 )
            {
                // 获取每一位的数字
                $wei = $aimNumber % 10;  
                // 计算每一位的n次幂并加到和上面
                $sum += pow( $wei, $number );
                // 去掉末尾数字
                $aimNumber = floor( $aimNumber / 10 );  
            }

            if( $i == $sum )
            {
                echo $i;
                echo "<br>";
            }
        }
    }

第二种方案:

利用PHP中可以把字符串当数组处理的好处,先把数据转化成字符串,利用下标直接取出每一位 并进行运算!

/**
     * @author Lizisir <[email protected]>
     * 可以计算数字中具有特殊含义的数字
     * @param  int $number 数字的位数
     * @return null
     */
    function specialNumber( $number )
    {
        $numberNameList = [
                ‘独身数‘,
                ‘没有‘,
                ‘水仙花数‘,
                ‘四叶玫瑰数‘,
                ‘五角星数‘,
                ‘六合数‘,
                ‘北斗七星数‘,
                ‘八仙数‘,
                ‘九九重阳数‘,
                ‘十全十美数‘
            ];
        // 输出对应的特殊数字的名称 例如:水仙花数
        echo $numberNameList[ $number-1 ].":<br>";

        $start = pow( 10, $number-1 ) + 1;
        $end = pow( 10, $number );

        for ( $i = $start; $i < $end; ++ $i ) 
        { 
            // 接受数字每位的n次幂的和
            $sum = 0;    

            // 计算数字每位的n次幂的和
            $i = (string)$i;
            for($key=0; $key<$number; ++$key)
            {
                // 获取每一位的数字
                $wei = $i[$key];  
                // 计算每一位的n次幂并加到和上面
                $sum += pow( $wei, $number );  
            }
            
            if( $i == $sum )
            {
                echo $i;
                echo "<br>";
            }
        }
    }

第三部分:你可能会遇到的问题!

在代码测试时,你可能会遇到报错:

Fatal error:  Maximum execution time of 30 seconds exceeded

可行的一种解决方案:

进入到PHP的安装目录,修改php.ini文件:

找到:

max_execution_time=30

修改为:

max_execution_time=300或者更大值!


第四部分:本文代码的网盘地址!

链接:http://pan.baidu.com/s/1mhY7hMw

密码:74hq

时间: 2024-10-14 10:41:09

使用PHP实现水仙花数及各种特殊有趣数的输出的相关文章

C的一些简单练习题,关于水仙花数,求和,整数高低位输出,制定二进制位替换

#define _CRT_SECURE_NO_WARNINGS //输出一个整数的每一位 //1.低位输出到高位 #include <stdio.h> #include <stdlib.h> int main() { int a; printf("请输出一个数"); scanf("%d",&a); while(a) { printf("%d ",a % 10); a = a / 10; } system("

【笔试】3、水仙花数

/* * 题目:打印出所有的 "水仙花数 ",所谓 "水仙花数 "是指一个三位数,其各位数字立方和等于该数本身. 例如:153是一个 "水仙花数 ",因为153=1的三次方+5的三次方+3的三次方. * 时间:2015年7月27日14:29:13 * 文件:lianxi03.cpp * 作者:cutter_point */ #include <iostream> #include <fstream> using names

2017华为机试题--水仙花数

等了一个月终于等到华为给安排的实习生在线机试,把自己做的三道题记录了一下,也方便日后复习.这篇是第一题,没有什么特别的难度,经典的水仙花数题. 题目描述:水仙花数是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身.(例如:13+53+33=153),要求:输出1000范围内所有水仙花数及水仙花数之和. 输入描述:无 输出描述:1000以内所有水仙花数及总和. 输出例子: 第1个水仙花数:xxx 第2个水仙花数:xxx 第3个水仙花数:xxx ... 水仙花数总和为:xxx 1 p

筛选水仙花数

//水仙花数--个位的平方+十位的平方+百位的平方(等于==)该三位数 #include<stdio.h>int main(){ int ge,shi,bai; //从100开始筛选for(int i=100;i<1000;i++){ ge=i%10; shi=i/10%10; bai=i/100%10; if(a==ge*ge*ge+shi*shi*shi+bai*bai*bai){//水仙花数的判断条件 //输出 printf("%d\t",i); }} retu

js算法集合(一) 水仙花数 及拓展(自幂数的判断)

js算法集合(一) ★ 最近有些朋友跟我说对js中的一些算法感到很迷惑,知道这个算法到底是怎么回事,但是就是不会用代码把它写出来,这里我跟大家分享一下做水仙花数的算法的思路,并对其扩展到自幂数的算法,希望能对大家有所帮助. 1.验证一个数是否为水仙花数 ①要写水仙花数的算法,我们首先来了解一下什么是水仙花数,水仙花数是指一个 3位正整数 ,它的每个位上的数字的 3次幂之和等于它本身.(例如:1^3 + 5^3+ 3^3 = 153): ②了解了什么是水仙花数我们就开始分析该怎么下手.通过定义来看

51NOD 1016 水仙花数 V2(打表)

传送门 水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身.(例如:1^3 + 5^3 + 3^3 = 153,1634 = 1^4 + 6^4 + 3^4 + 4^4). 给出一个整数M,求 >= M的最小的水仙花数. Input 一个整数M(10 <= M <= 10^60) Output 输出>= M的最小的水仙花数,如果没有符合条件的水仙花数,则输出:No Solution Input示例 300 Output示例 370 解题思路:

水仙花数

描述 请判断一个数是不是水仙花数.其中水仙花数定义各个位数立方和等于它本身的三位数. 输入 有多组测试数据,每组测试数据以包含一个整数n(100<=n<1000) 输入0表示程序输入结束. 输出 如果n是水仙花数就输出Yes 否则输出No 样例输入 153 154 0 样例输出 Yes No 1 #include <stdio.h> 2 3 int main(){ 4 int number; 5 int sum; 6 int temp; 7 8 while(1){ 9 scanf(

如何用C#寻找100到999的所有水仙花数?

首先解释一下何为水仙花数:水仙花数只是自幂数的一种,严格来说是三位数的个位.十位.百位的3次幂数相加等于原来的数字,称为水仙花数.(例如:1^3 + 5^3+ 3^3 = 153) 那么如何通过C#语句来解决这个问题呢? 分析:想要找到百位的水仙花数,要解决的问题由两个,第一个是如何让计算机正确分离出百位数的个位.十位.百位的数字.第二个是如何将其不断循环让100到999都能经过检验. 第一个问题:将这个数值类型定义为整型int(这种数据类型的数字是没有小数点的) 最高位数字--对100整除,则

3 水仙花数

题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身. 例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方. 程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位. 1 @SuppressWarnings({"rawtypes","unchecked"}) 2 public class _003ShuiXianFlo