国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JavaScript定義及輸出螺旋矩陣的方法詳解

2019-11-19 14:48:37
字體:
來源:轉載
供稿:網友

本文實例講述了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(' ')) } },      // 向該方向移動      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();})();

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript數學運算用法總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript數組操作技巧總結》、《JavaScript事件相關操作與技巧大全》、《JavaScript操作DOM技巧總結》及《JavaScript字符與字符串操作技巧總結

希望本文所述對大家JavaScript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 山阴县| 兴化市| 车险| 四子王旗| 丰台区| 富裕县| 平南县| 吉首市| 麻栗坡县| 紫云| 邯郸市| 曲水县| 巩义市| 来安县| 梨树县| 邵阳县| 宽甸| 德清县| 高尔夫| 饶河县| 简阳市| 迁西县| 佳木斯市| 西城区| 嘉义市| 金平| 互助| 高清| 定结县| 宾川县| 孝昌县| 闽侯县| 故城县| 喜德县| 高安市| 新化县| 利辛县| 镇江市| 林州市| 寿阳县| 永昌县|