PHP 中利用递归模拟掷骰子,可以通过创建 rollDice() 函数,根据骰子的边数生成随机数字,并在得到骰子的最高面数时递归调用自身,最终返回模拟的骰子值。实战案例中,代码模拟掷十次六面骰子,输出掷骰子的结果。
PHP 中利用递归模拟掷骰子
简介
递归是一种编程技术,它允许函数调用自身。在模拟掷骰子时,我们可以使用递归来创建每个掷骰子的随机结果。本文将展示如何使用 PHP 中的递归来模拟掷骰子,并提供一个实战案例。
创建骰子函数
首先,创建一个名为 rollDice()
的函数。此函数将使用递归模拟掷骰子并返回一个随机数字:
function rollDice(int $sides = 6): int { if ($sides < 1) { throw new InvalidArgumentException("Invalid number of sides: $sides"); } $result = rand(1, $sides); if ($result == $sides) { $result += rollDice($sides); } return $result; }
函数说明
$sides
参数指定骰子的边数。$sides
小于 1,函数会引发异常。rand(1, $sides)
生成一个介于 1 和 $sides
之间的随机数字。$sides
(骰子的最高面数),递归调用 rollDice()
并将结果添加到初始结果中。实战案例
让我们创建一个简单的示例来演示 rollDice()
函数:
// 模拟掷一个六面骰子 10 次 for ($i = 1; $i <= 10; $i++) { $roll = rollDice(); echo "掷第 $i 次: $rolln"; }
运行结果
该代码会输出类似以下结果:
掷第 1 次: 2 掷第 2 次: 5 掷第 3 次: 6 掷第 4 次: 4 掷第 5 次: 3 掷第 6 次: 5 掷第 7 次: 1 掷第 8 次: 6 掷第 9 次: 4 掷第 10 次: 3