Code Kata:螺旋矩阵 javascript实现
| 1 | 2 | 3 | 4 | 5 |
| 16 | 17 | 18 | 19 | 6 |
| 15 | 24 | 25 | 20 | 7 |
| 14 | 23 | 22 | 21 | 8 |
| 13 | 12 | 11 | 10 | 9 |
如图所示,就是一个5*5的螺旋矩阵
我的思路如下:
第一步:拆分“层”数组
把矩阵根据层数分成N个连续的自然数组,根据如果每一层宽度为n的话,那么每一层一共就有4(n-1)个数字,且当n=1时个数为1

拆分数字代码
function splitNumbers(n,m){ /*将总数按照每一层拆分为N个数组*/
var arr = [];
if(n == 1){
arr[0] = 1 + m;
}
else{
for(var i=0;i<4*n-4;i++){
arr[i] = i + 1 + m;
}
}
return arr;
}
循环调用,n每次减2
var m = 0;
while(n > 0){
layerArray[count] = splitNumbers(n,m);
n = n - 2;
m = layerArray[count][layerArray[count].length - 1];
count++;
}
第二部:将其组装为一个“沙漏”数组
将第一步拆分好的数组取第1到n,以及2n-1到3n-2,分别组装到“沙漏”数组的两端,其中“沙漏”底部的数组需要倒序排列

部分代码
for(var i=0;i<totalLayers;i++){/*组装成漏斗数组*/
var index = i >= layerArray.length ? totalLayers - i - 1 : i;
var cloneArray = layerArray[index].concat();
if(i < totalLayers / 2){
spiralArray[i] = cloneArray.splice(0,totalLayers - index * 2);
}
else{
spiralArray[i] = cloneArray.splice(2 * (totalLayers - 2 * i) - 2,totalLayers - index * 2);
spiralArray[i] = spiralArray[i].reverse();
}
}
第三部:把“沙漏”数组填充为完整的矩阵
“沙漏”数组,第1层和倒数第n层不需要填充,从第2层开始,依次向两端填充每个“层”数组中的第n+m位以及4(n-1)-m,m位“沙漏”数组的层数

部分代码
for(var i=0;i<spiralArray.length;i++){/*填充漏斗*/
var index = i >= layerArray.length ? totalLayers - i - 1 : i;
for(var j=0;j<index;j++){
var cloneArray = layerArray[j].concat();
spiralArray[i].splice(j,0,cloneArray[cloneArray.length - i + j]);
spiralArray[i].splice(spiralArray[i].length - j,0,cloneArray[totalLayers - 2 * j + i - j - 1]);
}
}
全部代码 github地址:https://github.com/yux357/my-code-kata/blob/master/spiralNumbers.js
function splitNumbers(n,m){ /*将总数按照每一层拆分为N个数组*/
var arr = [];
if(n == 1){
arr[0] = 1 + m;
}
else{
for(var i=0;i<4*n-4;i++){
arr[i] = i + 1 + m;
}
}
return arr;
}
function spiralNumbers(n){
var layerArray = [];
var spiralArray = [];
var totalLayers = n;
var count = 0;
var m = 0;
while(n > 0){
layerArray[count] = splitNumbers(n,m);
n = n - 2;
m = layerArray[count][layerArray[count].length - 1];
count++;
}
for(var i=0;i<totalLayers;i++){/*组装成漏斗数组*/
var index = i >= layerArray.length ? totalLayers - i - 1 : i;
var cloneArray = layerArray[index].concat();
if(i < totalLayers / 2){
spiralArray[i] = cloneArray.splice(0,totalLayers - index * 2);
}
else{
spiralArray[i] = cloneArray.splice(2 * (totalLayers - 2 * i) - 2,totalLayers - index * 2);
spiralArray[i] = spiralArray[i].reverse();
}
}
for(var i=0;i<spiralArray.length;i++){/*填充漏斗*/
var index = i >= layerArray.length ? totalLayers - i - 1 : i;
for(var j=0;j<index;j++){
var cloneArray = layerArray[j].concat();
spiralArray[i].splice(j,0,cloneArray[cloneArray.length - i + j]);
spiralArray[i].splice(spiralArray[i].length - j,0,cloneArray[totalLayers - 2 * j + i - j - 1]);
}
}
return spiralArray;
}
Code Kata:螺旋矩阵 javascript实现的更多相关文章
- JavaScript螺旋矩阵
螺旋矩阵 螺旋矩阵指一个呈螺旋状的矩阵,其数字由第一行开始到右边不断变大,向下变大, ...
- LintCode-381.螺旋矩阵 II
螺旋矩阵 II 给你一个数n生成一个包含1-n^2的螺旋形矩阵 样例 n = 3 矩阵为 [ [ 1, 2, 3 ], [ 8, 9, 4 ], [ 7, 6, 5 ] ] 标 ...
- LintCode-374.螺旋矩阵
螺旋矩阵 给定一个包含 m x n 个要素的矩阵,(m 行, n 列),按照螺旋顺序,返回该矩阵中的所有要素. 样例 给定如下矩阵: [ [ 1, 2, 3 ], [ 4, 5, 6 ...
- LeetCode之螺旋矩阵
问题 螺旋矩阵 给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素. 示例 1: 输入: [ [ 1, 2, 3 ], [ 4, 5, 6 ], [ ...
- PAT 1050. 螺旋矩阵(25)
本题要求将给定的N个正整数按非递增的顺序,填入"螺旋矩阵".所谓"螺旋矩阵",是指从左上角第1个格子开始,按顺时针螺旋方向填充.要求矩阵的规模为m行n列,满足条 ...
- leetcode-Spiral Matrix II 螺旋矩阵2之python大法好,四行就搞定,你敢信?
Spiral Matrix II 螺旋矩阵 Given an integer n, generate a square matrix filled with elements from 1 to n2 ...
- Java-基础编程(螺旋矩阵&乘法表)
package cn.rick.study; import java.io.BufferedReader;import java.io.InputStreamReader;import java.ut ...
- NOIP 2014 普及组 T3 螺旋矩阵
[题意] 已知:n,r,c(n<=30000) 条件:给定n行n列的螺旋矩阵(从矩阵的左上角(1,1)出发,初始时向右移动:如果前方是未曾经过的格子, 则继续前进,否则右转:重复上述操作直至经过 ...
- PAT-乙级-1050. 螺旋矩阵(25)
1050. 螺旋矩阵(25) 时间限制 150 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 本题要求将给定的N个正整数按非递增的 ...
随机推荐
- 初窥图像识别与k-means算法
前段时间做了一个车型识别的小项目,思路是利用k-means算法以及词袋模型来做的. 近年来图像识别的方法非常非常多,这边只记录一下我那个项目的思路,核心思想是k-means算法和词汇树. 很遗憾没有做 ...
- Grunt打包之seajs项目【转】
原文:http://www.cnblogs.com/accordion/p/4508154.html grunt与seajs grunt是前端流行的自定义任务的脚手架工具,我们可以使用grunt来为我 ...
- 如何成为一个javascript高手【转载】
原文网址: http://www.cnblogs.com/keva/p/how-to-become-a-javascript-badass.html 英文网址:http://www.clientc ...
- C++雾中风景2:struct还是class?
之前因为都在忙着毕业的开题答辩与投稿论文的事宜,一直没有时间更新这个系列的文章.师弟看了上一篇雾中风景的文章,希望我继续把这个系列的文章写下去.坦白说,C++的特性很多,这也不是教学指南的文章,我会选 ...
- Spring IOC容器分析(3) -- DefaultListableBeanFactory
上一节介绍了封装bean对象的BeanDefinition接口.从前面小结对BeanFactory的介绍中,我们知道bean对象是存储在map中,通过调用getBean方法可以得到bean对象.在接口 ...
- Windows常用shell命令大全
Windows常用shell命令大全 基于鼠标操作的后果就是OS界面外观发生改变, 就得多花学习成本.更主要的是基于界面引导Path与命令行直达速度是难以比拟的.另外Geek很大一部分是键盘控,而非鼠 ...
- C# 读写文本文件乱码解决方案
在使用C#对文本文件读取的时候,如果其中包含了中文,经常会出现乱码.一般解决是在StreamReader加一个编码,我使用的是Encoding.UTF8,一般情况下使用这个参数就可以.但是,在这次我使 ...
- git 分支合并 强制合并
常用的提交流程git add *.XXXgit commit -m "备注....." # 提交到本地分支git fetch git merge #"合并远程分支情况,如 ...
- 给GridControl中的某列添加图片
要让GridControl的某列显示图片只需要数据源中有图片就可以正确显示 1.给DataSet添加一列,格式为image ds.Tables[].Columns.Add("SIGN&quo ...
- StackExchange.Redis学习笔记(四) 事务控制和Batch批量操作
Redis事物 Redis命令实现事务 Redis的事物包含在multi和exec(执行)或者discard(回滚)命令中 和sql事务不同的是,Redis调用Exec只是将所有的命令变成一个单元一起 ...