> php教程 > PHP源码 > PHP 用二维矩阵生成一个给定层数的杨辉(PASCAL)三角形

PHP 用二维矩阵生成一个给定层数的杨辉(PASCAL)三角形

WBOY
풀어 주다: 2016-06-02 09:14:17
원래의
1122명이 탐색했습니다.
跳至 [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 
 } 
 ?>
로그인 후 복사
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿