> php教程 > PHP源码 > 본문

php版螺旋矩阵(由里到外)

PHP中文网
풀어 주다: 2016-05-26 08:21:13
원래의
1443명이 탐색했습니다.


<?php
function matrix($n){
    $y = $x = ($n - 1) / 2;
    $num = 2;
    $total = pow($n, 2);
    $arr = array_fill(0, $n, array_fill(0, $n, 1));
    $i = 0;
    $limit = 1;

    while ($num <= $total) {
         for ($j = 0; $num <= $total && $j < $limit; ++$j) { 
             switch ($i) {
                 case 0 :
                     ++$y;
                     break;
                 case 1 :
                     ++$x;
                     break;
                 case 2 :
                     --$y;
                     break;
                 case 3 :
                     --$x;
                     break;
             }
             $arr[$x][$y] = $num++;
         }
         if ($i % 2 == 1) {
             ++$limit;
         }
         $i = ($i + 1) % 4;
     } 
     return $arr;
}

$arr = matrix(6);
print_r($arr);
로그인 후 복사

                   

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿