首頁 >web前端 >js教程 >在JavaScript中如何定義及輸出螺旋矩陣

在JavaScript中如何定義及輸出螺旋矩陣

亚连
亚连原創
2018-06-23 14:23:101403瀏覽

這篇文章主要介紹了JavaScript定義及輸出螺旋矩陣的方法,簡單描述了螺旋矩陣的概念、原理並結合實例形式分析了javascript定義與輸出螺旋矩陣的具體操作技巧,需要的朋友可以參考下

本文實例敘述了JavaScript定義及輸出螺旋矩陣的方法。分享給大家供大家參考,具體如下:

昨晚無意看到這樣一個演算法題目,然後就想著用js來實現。
昨晚草草寫完後感覺程式碼很醜,很臭,於是今晚又花點時間重構了一下,感覺變得優雅了。

什麼是螺旋矩陣

螺旋矩陣是指一個呈螺旋狀的矩陣,它的數字由第一行開始到右邊不斷變大,向下變大,向左變大,向上變大,如此循環。

如圖:

實作效果

實作程式碼

(function() {
  var map = (function() {
    function map(n) {
      this.map = [], this.row = 0, this.col = -1, this.dir = 0, this.n = n;
      // 建立个二维数组
      for (var i = 0; i < this.n; i++) { this.map.push([]); }
      // 定义移动的顺序为 右,下,左,上
      var order = [this.right, this.bottom, this.left, this.up];
      i = 0;
      do {
        // 能移动则更新数字,否则更改方向
        order[this.dir % 4].call(this) ? i++ : this.dir++;
        // 赋值
        this.map[this.row][this.col] = i;
      } while (i < n * n);
    }
    map.prototype = {
      print: function() { for (var i = 0; i < this.n; i++) { console.log(this.map[i].join(&#39; &#39;)) } },
      // 向该方向移动
      left: function() { return this.move(this.row, this.col - 1); },
      right: function() { return this.move(this.row, this.col + 1); },
      up: function() { return this.move(this.row - 1, this.col); },
      bottom: function() { return this.move(this.row + 1, this.col); },
      // 如果坐标在范围内,并且目标没有值,条件满足则更新坐标
      move: function(row, col) {
        return (0 <= row && row < this.n) && (0 <= col && col < this.n) && !this.map[row][col] && (this.row = row, this.col = col, true);
      },
    };
    return map;
  })();
  new map(6).print();
})();

上面是我整理給大家的,希望今後會對大家有幫助。

相關文章:

使用微信小程式如何實作圖片選擇區域裁切

在vue中有關eventbus的詳細解讀

在Angular中如何使用toDoList

#在React Native中如何使用Fetch發送網路請求

########################################################################在vue中如何實作目前頁面分享其他頁面功能############在Vue中如何實作按需載入######

以上是在JavaScript中如何定義及輸出螺旋矩陣的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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