国产探花免费观看_亚洲丰满少妇自慰呻吟_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程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 成武县| 黄大仙区| 巧家县| 郓城县| 垫江县| 富锦市| 芮城县| 文化| 巩留县| 肇庆市| 宁晋县| 阜阳市| 巴林左旗| 定襄县| 湘阴县| 濉溪县| 武乡县| 红原县| 江都市| 新邵县| 鄂伦春自治旗| 三穗县| 汝城县| 河西区| 南陵县| 宁河县| 汉沽区| 穆棱市| 平凉市| 连州市| 玉林市| 孟连| 孝感市| 昂仁县| 安徽省| 丹巴县| 县级市| 大宁县| 张家港市| 龙门县| 新蔡县|