这是一道某公司的算法题,我们姑且称之为“数字绕圈算法”。
题目:给定一个数字N,以此生成一个N^2的二维矩阵,以某个方向为基准从1开始填充数字。假设数字5那么开始绕圈,最终的结果显示为:
1 16 15 14 13
2 17 24 23 12
3 18 25 22 11
4 19 20 21 10
5 6 7 8 9
代码如下:
var num = 3, res; // 定义全局变量 document.getElementById('btn').onclick = function(){ num = parseInt(document.getElementById('num').value) || num; res = []; for(var i =0;i<num; i++){ res[i] = []; for(var v=0;v<num;v++) res[i][v] = ''; } calc(num); print(); } //递归的算法 var calc = function(n, r){ r = r || 0; // 圈数 var x=y=0, // 初始化坐标 start = r, // 开始位置 end = n-1, // 结束位置 startNum= !r ? 1 : n * 4 * r +1; //显示的数字 // 奇数情况下判断是否是最后一个数字 if (start==end){ res[start][start] = Math.pow(num,2); return; } // 四个方向填充 for(x=start; x<end; x++){ res[x][r] = startNum++; } for(y=start; y<end; y++){ res[x][y] = startNum++; } for(; x>r; x--){ res[x][y] = startNum++; } for(; y>r; y--){ res[x][y] = startNum++; } // 偶数情况下判断判断完结 if ( x>Math.ceil(n/2)){ return; } calc(--n, ++r); } //显示结果 var resDiv = document.getElementById('res'); var print = function(){ var str = []; for(var i in res){ for(var m in res[i]){ str.push('<div>', res[i][m], '</div>'); } str.push('<br/>'); } resDiv.innerHTML = str.join(''); }
相关推荐
这道名为“面试题 数字绕圈(含答案)”的题目是面试中常见的逻辑思维与编程挑战,尤其在IT行业中,这种类型的问题被用来评估应聘者的观察力、问题解决能力和编程技能。通常这类问题会涉及一定的数学规律和编程实现,...
数字信号处理理论算法与实现胡广书第二版-数字信号处理 理论算法与实现 胡广书 第二版.part04.rar 差不多700页
L变换、DCT及其在图像压缩中的应用)、信号处理中若干典型算法(如抽取与插值、子带分解、调制与解调、反卷积、SVD、独立分量分析及同太民滤波等)、平稳随机信号的基本概念、经典功率谱估计、参数模型功率谱估计、...
《数字信号处理理论、算法与实现》是2003年清华大学出版社出版的图书,作者是胡广书。该书系统地介绍了数字信号处理的理论、相应的算法及这些算法的软件与硬件实现。
### 基于LSB的数字水印算法及MATLAB实现 #### 1. 数字水印技术概述 数字水印技术是一种新兴的信息隐藏技术,主要用于保护多媒体信息(如图像、音频、视频)的版权。它通过将某种标识性的信息(如商标、序列号等)...
《数字信号处理理论、算法与实现》是胡广书教授编著的一本经典教材,主要针对数字信号处理领域的核心概念、基本理论以及实际应用进行了深入浅出的阐述。该书第三版于2012年出版,反映了近年来该领域的新发展和技术...
《Visual C++数字图像处理典型算法及实现》一书,主要涵盖了C++在数字图像处理领域的广泛应用和技术。作为一本已绝版的专业书籍,它对于学习和研究C++图像处理技术的人来说,具有很高的参考价值。书中深入浅出地讲解...
数字图像处理算法实现的源程序,编译环境VC6.0.包括图像点运算,几何变换,滤波,傅立叶变换等
《数字信号处理:理论算法与实现》是胡广书教授编著的一本经典教材,主要针对数字信号处理领域的基础知识、核心算法以及实际应用进行了深入浅出的讲解。这本书的第二版更加完善,涵盖了从基本概念到高级技术的广泛...
《数字信号处理:理论、算法与实现》是胡广书教授撰写的一本经典教材,它深入浅出地探讨了数字信号处理的各个方面。这本教材的第二版配备了一个光盘,包含了C语言、FORTRAN和MATLAB的源代码,旨在帮助读者更直观地...
《精通Visual C++数字图像处理典型算法及实现》是一本深入浅出的书籍,由张宏林编著,旨在帮助读者掌握使用Visual C++进行数字图像处理的技术和方法。源码的分享使得理论与实践结合更为紧密,为学习者提供了宝贵的...
《精通Visual C++数字图像处理典型算法及实现(第2版)》是一本深度解析数字图像处理技术,并结合Visual C++编程环境进行实践操作的专著。这本书旨在为初学者和有一定基础的开发者提供一个全面了解和掌握数字图像...
《数字信号处理:理论算法与实现》是胡广书教授的经典著作,第二版更是深受广大读者和学习者喜爱。这本书深入浅出地介绍了数字信号处理的基础理论、算法以及其实现方法,是通信工程、电子工程、计算机科学等相关领域...
银行家算法-javascript实现.zip 银行家算法-javascript实现.zip银行家算法-javascript实现.zip银行家算法-javascript实现.zip银行家算法-javascript实现.zip银行家算法-javascript实现.zip银行家算法-javascript实现...
精通Visual C++数字图像处理典型算法及实现(高清晰).PDF.part1 第二版 张宏林
在这个资源包中,包含的是使用Python纯算法实现RSA数字签名的代码、相关的PPT演示文稿以及文档,这些内容将帮助我们深入理解RSA数字签名的工作原理和实现过程。 1. **RSA算法基础** RSA算法基于大数因子分解的困难...
这里的压缩包文件聚焦于RSA算法的C++实现以及数字签名的相关程序。RSA是一种非对称加密算法,由Ron Rivest、Adi Shamir和Leonard Adleman在1977年提出,因其发明者的名字首字母命名。它广泛应用于数字证书、网络通信...
数字信号处理理论算法与实现胡广书第二版-数字信号处理 理论算法与实现 胡广书 第二版.part02.rar 差不多700页
数字信号处理_理论、算法与实现_第3版_胡广书编著(高清扫描版带目录)
本文主要探讨的是一系列C++实现的数字加网算法,具体包括调频加网和抖动算法,如Bayer算法、Halftone算法、Stucki算法、Jarvis算法以及Floyd-Steinberg算法。 1. **Bayer抖动算法**:Bayer算法是最早的色彩滤波阵列...