网站推广.NET

网站推广.NET

php实现水仙花数的4个示例 1000以内的水仙花数 水仙花数vb c语言输出水仙花

来源:互联网

水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。(例如:1^3 + 3^3+ 5^3 = 153)这篇文章主要介绍了php实现水仙花数的4个示例分享,需要的朋友可以参考下:

示例1,代码如下:

13356" name="code"><?php for($q=1;$q<=9;$q++){    for($w=0;$w<=9;$w++){      for($e=0;$e<=9;$e++){        if($q*$q*$q + $w*$w*$w + $e*$e*$e ==         100*$q + 10*$w + $e){           echo "$q $w $e "."<p>";        }      }    }}?&gt;

示例2,代码如下:
<?php function cube( $n ){    return $n * $n * $n;}function is_narcissistic ( $n ){    $hundreds = floor( $n / 100);    //分解出百位    $tens = floor( $n / 10 ) % 10;    //分解出十位    $ones = floor( $n % 10 );    //分解出个位    return (bool)(cube($hundreds)+cube($tens)+cube($ones) == $n);} for ( $i = 100; $i < 1000; ++ $i ){    if ( is_narcissistic($i) )        echo $i."\n";}?>
示例3,代码如下:
<?php //阿姆斯特朗数:一个k位数,它的每个位上的数字的k次幂之和等于它本身。(例如:1^3 + 5^3 + 3^3 = 153)class Armstrong { static function index(){  for ( $i = 100; $i < 100000; $i++ ) {   echo self::is_armstrong($i) ? $i . &#39;<br>' : '';  } } static function is_armstrong($num){  $s = 0;  $k = strlen($num);  $d = str_split($num);  foreach ($d as $r) {   $s += bcpow($r, $k);  }  return $num == $s; }}Armstrong::index();

示例4,代码如下:
  <title></title><?php function winter($num) {       if($num<1000){       //定义个位       $ge=$num%10;       //定义十位       $ten=(($num%100)-$ge) /10;       //定义百位       /*floor取整,忽略小数点后面的所有数*/       $hundred=floor($num/100);       $sum1=$ge*$ge*$ge+$ten*$ten*$ten+$hundred*$hundred*$hundred;       if($sum1==$num){               return 1;                } else{                        return 0;                        }               } else{                       return -1;                       }         }         if(winter(371)==-1) {                 echo "大于1000的数";            }else{                  if(winter(371)) {                          echo "Yes";                          }     else{   echo "No";   }        }?>

以上就介绍了php实现水仙花数的4个示例,包括了水仙花数,php方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

水仙花数vb代码