PHP 用二维矩阵生成一个给定层数的杨辉(PASCAL)三角形
Jun 02, 2016 am 09:14 AM
跳至
[3]
[全屏预览]
<meta charset="utf-8"> <title>杨辉三角形 Pascal Triangle</title> <?php if ($_POST['button']){ //定义未来三角形的层数为常数 N define("N",$_POST['number']); //首先,把用来显示三角形的2维矩阵(2N*(N+1))的每个元素清理成零 for($i=0;$i<N+1;$i++) for($j=0;$j<2*N;$j++) $a[$i][$j]= 0; $a[0][N]=1; //再将矩阵第一行中间位置的元素, 赋以 1 /* 这样一来,杨辉三角形的形成规律便是:从第二行开始, * 每一个显示数字的元素,其数字的数值是, * 它头顶元素的左边邻居的数值, * 与它头顶元素的右边邻居的数值之和。 * 据此,给有关元素赋于相应的值。 */ for ($i=1;$i<N;$i++) //从第二层开始赋值: $i=1; for ($j=1;$j<2*N;$j++) //按上述规律,求左上角元素数值,与右上角元素数值之和 $a[$i][$j]=$a[$i-1][$j-1]+$a[$i-1][$j+1]; // 打印输出建成的矩阵 echo '你要求建立的'.N.'层杨辉三角形如下:'.'<table>'; for($i=0;$i<N;$i++){ echo '<tr>'; for($j=0;$j<2*N+1;$j++){ echo '<td width="35" height="15"><center>'; if ($a[$i][$j] !=0) //只打印不为零的数字 echo $a[$i][$j];//只打印不为零的数字, echo '</center></td>'; } echo '</tr>'; } echo '</table>'; echo '<br><a href="pascal.php">返回</a>'; }else{ ?> <form action="pascal.php" method="post"> 输入层数: <input type="number" name="number"> <input type="submit" name="button" value="提交(最多12层)"> </form> <?php } ?>
登入後複製
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章
兩個點博物館:邦格荒地地點指南
4 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章
兩個點博物館:邦格荒地地點指南
4 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章標籤

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)