php已知一个三位数是456,判断是不是水仙花数求代码
2个回答
展开全部
<?php //定义一个数判断是不是 水仙花数
function check_sxh_number($str)
{
$is = true;
$one = ($str % 10);
$two = ($str / 100) % 10;
$three = ($str / 10) % 10;
$num = 0;
$num = $one * $one * $one + $two * $two * $two + $three * $three * $three;
if ($num == $str) {
$is = true; //是
} else {
$is = false; //否
}
return $is;
}
$str = 456;
$data = check_sxh_number($str);
if($data === true){
echo '是';
}else{
echo '否';
}
function check_sxh_number($str)
{
$is = true;
$one = ($str % 10);
$two = ($str / 100) % 10;
$three = ($str / 10) % 10;
$num = 0;
$num = $one * $one * $one + $two * $two * $two + $three * $three * $three;
if ($num == $str) {
$is = true; //是
} else {
$is = false; //否
}
return $is;
}
$str = 456;
$data = check_sxh_number($str);
if($data === true){
echo '是';
}else{
echo '否';
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
水仙花数是指一个 n 位数 (n>=3),它的每个位上的数字的 n 次幂之和等于它本身。 例如:153 是一个水仙花数,因为 153 = 1^3 + 5^3 + 3^3。 在 PHP 中,我们可以通过以下步骤判断一个数是否为水仙花数:
将数字转换为字符串,以便我们可以轻松地访问每一位。
计算数字的位数(n)。
遍历每一位数字,将其转换为整数,然后计算其 n 次幂。将所有这些值相加。
如果得到的总和等于原始数字,则该数字是水仙花数。
function isNarcissistic($num) {
$strNum = strval($num);
$n = strlen($strNum);
$sum = 0;
for ($i = 0; $i < $n; $i++) {
$sum += pow((int)$strNum[$i], $n);
}
return $sum == $num;
}
$num = 456;
if (isNarcissistic($num)) {
echo "$num 是水仙花数";
} else {
echo "$num 不是水仙花数";
}
将数字转换为字符串,以便我们可以轻松地访问每一位。
计算数字的位数(n)。
遍历每一位数字,将其转换为整数,然后计算其 n 次幂。将所有这些值相加。
如果得到的总和等于原始数字,则该数字是水仙花数。
function isNarcissistic($num) {
$strNum = strval($num);
$n = strlen($strNum);
$sum = 0;
for ($i = 0; $i < $n; $i++) {
$sum += pow((int)$strNum[$i], $n);
}
return $sum == $num;
}
$num = 456;
if (isNarcissistic($num)) {
echo "$num 是水仙花数";
} else {
echo "$num 不是水仙花数";
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询