今天碰到一个比较有意思的问题, 就是把A到Y这25个字母以下面的形式输出出来
/** * 根据传入的行数和列数生成螺旋数组 * @author chenqionghe * @param int $row 行数 * @param int $col 列数 * @return array */function rotationSort($row=5,$col=5){ $k=1; $result = array(); $small = $col < $row ? $col : $row; $count = ceil($small / 2); for($i=0; $i<$count; $i++) { $maxRight = $col-1-$i;//右边最大坐标 $maxBottom = $row -1 -$i;//下面最大坐标 for($j=$i; $j<=$maxRight; $j++) //构造上边一条线 纵坐标最小,横坐标递增 { $result[$i][$j] = $k++; } for($j=$i; $j<$maxBottom; $j++) //构造右边一条线 纵坐标递增,横坐标最大 { $result[$j+1][$maxRight] = $k++; } for($j=$maxRight-1;$j>=$i; $j--) //构造下边一条线 纵坐标最大,横坐标递减 { if($result[$maxBottom][$j]) break; $result[$maxBottom][$j] = $k++; } for($j=$maxBottom-1;$j>$i;$j--) //构造左边一条线 纵坐标递减,横坐标最小 { if($result[$j][$i]) break; $result[$j][$i] = $k++; } } return $result;}该函数由伟大的诗人chenqionghe撰写, 调用时传数两个参数行数和列数,即可返回螺旋数组, 好人做到底吧,再定义一个以表格输出的方式,打印该螺旋数组直观一点,方法如下
/** * 以table格式输出数组 * @param $result 螺旋数组 * @param $row 行数 * @param $col 列数 */function printArray($result,$row,$col){ echo '<table border=1 style='width:500px;'>'; for($i=0;$i<$row;$i++) { echo '<tr>'; for($j=0;$j<$col;$j++) { echo '<td style='padding: 50px;'>'.$result[$i][$j].'</td>'; } echo '<tr>'; } echo '</table>';}然后,我们来调用一下上面的方法,生成一个5*5的螺旋数组
$row = 5;$col = 5;$arr = rotationSort($row,$col);printArray($arr,$row,$col);执行结果如下
$arr = array('A','B','C','D','E','F', 'G', 'H', 'I', 'J', 'K', 'L', 'N', 'M', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z',);输出的时候稍做改动即能输出A-Y的螺旋数组,完整代码如下
<?php/** * 根据传入的行数和列数生成螺旋数组 * @author chenqionghe * @param int $row 行数 * @param int $col 列数 * @return array */function rotationSort($row=5,$col=5){ $k=1; $result = array(); $small = $col < $row ? $col : $row; $count = ceil($small / 2); for($i=0; $i<$count; $i++) { $maxRight = $col-1-$i;//右边最大坐标 $maxBottom = $row -1 -$i;//下面最大坐标 for($j=$i; $j<=$maxRight; $j++) //构造上边一条线 纵坐标最小,横坐标递增 { $result[$i][$j] = $k++; } for($j=$i; $j<$maxBottom; $j++) //构造右边一条线 纵坐标递增,横坐标最大 { $result[$j+1][$maxRight] = $k++; } for($j=$maxRight-1;$j>=$i; $j--) //构造下边一条线 纵坐标最大,横坐标递减 { if($result[$maxBottom][$j]) break; $result[$maxBottom][$j] = $k++; } for($j=$maxBottom-1;$j>$i;$j--) //构造左边一条线 纵坐标递减,横坐标最小 { if($result[$j][$i]) break; $result[$j][$i] = $k++; } } return $result;}/** * 以table格式输出数组 * @param $rotationArr 要输出的内容 * @param $result 螺旋数组 * @param $row 行数 * @param $col 列数 */function printArray($rotationArr,$result,$row,$col){ echo '<table border=1 style='width:500px;'>'; for($i=0;$i<$row;$i++) { echo '<tr>'; for($j=0;$j<$col;$j++) { //echo '<td style='padding: 50px;'>'.$result[$i][$j].'</td>'; echo '<td style='padding: 50px;'>'.$rotationArr[$result[$i][$j]-1].'</td>'; } echo '<tr>'; } echo '</table>';}$arr = array('A','B','C','D','E','F', 'G', 'H', 'I', 'J', 'K', 'L', 'N', 'M', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z',);$row = 5;$col = 5;$rotationArr = rotationSort($row,$col);printArray($arr,$rotationArr,$row,$col);最终输出结果如下:
郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。
新闻热点
疑难解答