首頁 >後端開發 >php教程 >PHP實現蛇形矩陣,回環矩陣及數字螺旋矩陣的方法圖文詳解

PHP實現蛇形矩陣,回環矩陣及數字螺旋矩陣的方法圖文詳解

墨辰丷
墨辰丷原創
2018-05-22 10:04:181488瀏覽

這篇文章主要介紹了PHP實現蛇形矩陣,回環矩陣及數字螺旋矩陣的方法,結合具體實例形式分析了蛇形矩陣,回環矩陣及數字螺旋矩陣的概念、表示方法及php實現技巧,需要的朋友可以參考下

具體如下:

回環矩陣指的是從一開始,不斷按照上、右、下、左順序依序增大的矩陣序列,範例:

1 2 3
8 9 4
7 6 5

現在要求:

輸入: m、n,分別代表行數和列數
輸出: m * n 的回環矩陣

範例:

輸入:

7 8

輸出:

1 2 3 4 5 6 7 8
26 27 28 29 30 31 32 9
25 44 45 46 47 48 33 10
24 43 54 57 56 49 34 11
23 42 53 52 51 50 35 12
22 41 40 39 38 37 36 13
21 20 19 18 17 16 15 14

接下來我們用PHP 來實現,這裡我們將其封裝成函數呼叫

#第一種思路

##直接依照上、右、下、左的順序進行遍歷,計算好遍歷層數就OK了

function snake($row = 5, $col = 5)
{
  // 结果集
  $res = array();
  // 初始值
  $start = 1;
  // 当前遍历层数
  $flag = intval(($row + 1) / 2);
  for ($i = 1; $i <= $flag; $i++) {
    $startX = $i - 1;
    $startY = $i - 1;
    $width = $col - $i + 1;
    $height = $row - $i + 1;
    // 上
    for ($u = $startY; $u < $width; $u++) {
      $res[$startX][$u] = $start;
      $start += 1;
    }
    // 右
    for ($r = $startX + 1; $r < $height; $r++) {
      $res[$r][$u-1] = $start;
      $start += 1;
    }
    // 下
    for ($d = $u - 1 - 1; $d >= $startY; $d--) {
      $res[$r-1][$d] = $start;
      $start += 1;
    }
    // 左
    for ($l = $r - 1 - 1; $l >= $startX + 1; $l--) {
      $res[$l][$d+1] = $start;
      $start += 1;
    }
  }
  // 输出
  for ($i = 0; $i < $row; $i++) {
    for ($j = 0; $j < $col; $j++) {
      echo $res[$i][$j] . " ";
    }
    echo "<br />";
  }
}
snake(7, 8);

第二種想法

這種思路與第一種思路類似,不過是透過一個while 全部遍歷,然後透過一個標誌位up right down left 來判斷與修改當前方向,透過while 內的if 來對標誌位進行判斷,這種就不貼程式碼了

第三種想法

使用一個迭代器來控制方向,然後進行m * n 次循環,透過判斷寬高和isset來確定是否轉彎,思路很棒,代碼量大大減少,表示沒有想到這種方式。 。

/* *
 * @param $w : 宽
 * @param $h : 高
 * @param $s : 起始数字
 * @param $x, $y : 起始位置坐标 只能从四顶点开始
 * @param $r :方向 默认顺时间 false为逆时针
 *
 */
function print_matrix($w, $h, $s = 1, $l = 1, $x = 0, $y = 0, $r = true) {
  // 表示四个方向
  $R = array(array(1, 0), array(0, 1), array(-1, 0), array(0, -1));
  !$r && $R = array_reverse($R);
  // 创建一个无限迭代器
  $iterator = new InfiniteIterator(new ArrayIterator($R));
  $iterator->rewind();
  list($_x, $_y) = $iterator->current();
  $result = [];
  $result[$x][$y] = $s;
  for ($i = $s+1; $i < ($s + $w * $h); $i++) {
    $new_x = $x + $_x;
    $new_y = $y + $_y;
    if (0 <= $new_x && 0 <= $new_y && $new_x < $w && $new_y < $h && !isset($result[$new_x][$new_y])) {
      $result[$new_x][$new_y] = $i;
      $x = $new_x;
      $y = $new_y;
    } else {
      $iterator->next();
      list($_x, $_y) = $iterator->current();
      $i--;
    }
  }
  // 打印
  for ($i = 0; $i < $h; $i++) {
    for ($j = 0; $j < $w; $j++) {
      echo $result[$j][$i], "\t";
    }
    echo "<br />";
  }
}

相關推薦:

##PHP怎麼操作二維陣列

矩陣轉置

#PHP實作順時針列印

矩陣(螺旋矩陣)的方法範例

#PHP實作二維陣列的

矩陣轉置操作的方法及案例

########################################################

以上是PHP實現蛇形矩陣,回環矩陣及數字螺旋矩陣的方法圖文詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn