问题
输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵:
1 | 2 | 3 | 4 |
5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 |
则依次打印出数字1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10.
解决方法
就是一圈一圈地打印,只要控制好循环就可以。
注意单行单列的情况。
实现代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
<?php function printMatrix( $matrix ) { $row = count ( $matrix ); $col = count ( $matrix [0]); if ( $row == 0 || $col == 0) return $matrix ; $result = array (); $left = 0; $right = $col -1; $top = 0; $bottom = $row -1; while ( $left <= $right && $top <= $bottom ){ for ( $i = $left ; $i <= $right ;++ $i ){ array_push ( $result , $matrix [ $top ][ $i ]); } for ( $i = $top +1; $i <= $bottom ;++ $i ) array_push ( $result , $matrix [ $i ][ $right ]); if ( $top != $bottom ){ for ( $i = $right -1; $i >= $left ;-- $i ) array_push ( $result , $matrix [ $bottom ][ $i ]); } if ( $left != $right ){ for ( $i = $bottom -1; $i > $top ;-- $i ) array_push ( $result , $matrix [ $i ][ $left ]); } $left ++; $right --; $top ++; $bottom --; } return $result ; } |
原文链接:http://blog.csdn.net/acingdreamer/article/details/68943174
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
暂无评论内容