PHP怎么计算给定数n的阶乘
这篇文章主要介绍“PHP怎么计算给定数n的阶乘”,在日常操作中,相信很多人在PHP怎么计算给定数n的阶乘问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP怎么计算给定数n的阶乘”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
成都创新互联是一家专注于成都网站设计、成都网站制作与策划设计,阿鲁科尔沁网站建设哪家好?成都创新互联做网站,专注于网站建设10余年,网设计领域的专业建站公司;建站业务涵盖:阿鲁科尔沁等地区。阿鲁科尔沁做网站价格咨询:13518219792
一个正整数的阶乘(factorial)是指所有小于及等于该数的正整数的积。因此,给定整数N的阶乘就是指:
1 × 2 × 3×...× (n-1) × n
求阶乘很简单,是刚入门编程的同学一定会遇到的一个编程题,有多种实现方法。本文会给大家从for循环、while循环、do-while循环,以及递归角度来介绍多种实现阶乘的方法。
方法1:使用for循环实现N的阶乘
实现思想:
因为求n的阶乘,就是求1乘以2乘以3...一直乘到n的乘积。所以for循环的初始条件可设置为
i = 1
,限制条件可以是i <= n
或者i < n+1
。然后循环体中的就是乘法运算了,将每次循环的 i 值相乘,得到一个乘积
最后输出乘积即可
下面看看实现方法:
"; } Factorial(5); Factorial(10); Factorial(100); ?>
$sum *= $i
语句等价于$sum=$sum*$i
,*=
赋值运算符可以将运算符左边的变量乘以右边表达式的值赋给左边的变量。注意:因为0乘以任何值都是0,所以变量$sum的初始值要为1。
我们看看输出结果:
了解了for循环实现N的阶乘的方法,while循环和do-while循环的实现方法也就知道的差不多了(它们的实现思维是一样的)。
方法2:使用while循环实现N的阶乘
"; } Factorial(1); Factorial(2); Factorial(3); Factorial(11); ?>
输出结果:
方法3:使用do-while循环实现N的阶乘
"; } Factorial(2); Factorial(3); Factorial(4); Factorial(10); ?>
输出结果:
对比一下,方法1、方法2和方法3,是不是发现它们很相似!
好了另一个重点来了,下面看看递归是如何实现N的阶乘的。
方法4:使用递归实现N的阶乘
那么递归是什么呢?简单来说,递归就是程序调用自身、函数不断引用自身,直到引用的对象已知。构成递归需满足以下两个条件:
子问题需与原始问题为同样的事,且更为简单。
不能无限制地调用本身,必须有一个出口,化简为非递归状况处理。
按照递归的思维,阶乘可以用如下的公式表示:
f(1) = 1 f(n) = n * f(n-1) {n>1}
因此,用 PHP 实现递归求N阶乘的代码如下:
"; echo "3 的阶乘为: " .Factorial(3)."
"; echo "4 的阶乘为: " .Factorial(4)."
"; echo "10 的阶乘为: " .Factorial(10); ?>
输出结果:
到此,关于“PHP怎么计算给定数n的阶乘”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!
分享标题:PHP怎么计算给定数n的阶乘
标题来源:http://scyanting.com/article/gphdgg.html