这是一道某公司的算法题,我们姑且称之为“数字绕圈算法”。
题目:给定一个数字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行业中,这种类型的问题被用来评估应聘者的观察力、问题解决能力和编程技能。通常这类问题会涉及一定的数学规律和编程实现,...
1)利用C\C++语言实现DSA算法。 2)DSA中的Hash函数采用SHA算法。 (1)消息填充:因为我们存储的时候是以字节为单位存储的,所以消息的长度(单位:位)一定是 8 的倍数。而我们填充的时候也一定是 8 位、8 位...
L变换、DCT及其在图像压缩中的应用)、信号处理中若干典型算法(如抽取与插值、子带分解、调制与解调、反卷积、SVD、独立分量分析及同太民滤波等)、平稳随机信号的基本概念、经典功率谱估计、参数模型功率谱估计、...
本主题将深入探讨如何使用C语言实现数字信号处理算法,主要包括信号的发生、信号采集以及滤波算法。 首先,我们要了解数字信号的发生。在C语言中,可以使用循环结构和数学函数来生成各种类型的数字信号,如正弦波、...
《数字信号处理——理论、算法与实现》是胡广书教授的一本经典教材,它深入浅出地介绍了数字信号处理的基础知识、核心算法及其在实际中的应用。这本书的答案集为学习者提供了宝贵的参考,帮助他们理解和掌握课程内容...
《Visual C++数字图像处理典型算法及实现》一书,主要涵盖了C++在数字图像处理领域的广泛应用和技术。作为一本已绝版的专业书籍,它对于学习和研究C++图像处理技术的人来说,具有很高的参考价值。书中深入浅出地讲解...
《数字信号处理:理论算法与实现》是胡广书教授的经典著作,第二版更是深受广大读者和学习者喜爱。这本书深入浅出地介绍了数字信号处理的基础理论、算法以及其实现方法,是通信工程、电子工程、计算机科学等相关领域...
《数字信号处理:理论、算法与实现》是一本深入探讨数字信号处理领域的经典著作,它涵盖了数字信号处理的基础理论、核心算法以及实际应用。这本书的配套光盘包含了C语言、Fortran语言和Matlab的程序代码,为读者提供...
Visual+C++数字图像处理典型算法及实现 全书配套光盘
这里的压缩包文件聚焦于RSA算法的C++实现以及数字签名的相关程序。RSA是一种非对称加密算法,由Ron Rivest、Adi Shamir和Leonard Adleman在1977年提出,因其发明者的名字首字母命名。它广泛应用于数字证书、网络通信...
包涵三个RSA算法,c++是实现,数字签名的合集,三个独自的程序,可以独自编译运行,VC6.0下编译 包涵三个RSA算法,c++是实现,数字签名的合集,三个独自的程序,可以独自编译运行,VC6.0下编译
本文主要探讨的是一系列C++实现的数字加网算法,具体包括调频加网和抖动算法,如Bayer算法、Halftone算法、Stucki算法、Jarvis算法以及Floyd-Steinberg算法。 1. **Bayer抖动算法**:Bayer算法是最早的色彩滤波阵列...
《精通Visual C++ 数字图像处理典型算法及实现》 第2版 (张宏林) 扫描PDF版及源码 目录 第1章 Visual C++数字图像编程基础 第2章 图像感知与获取 第3章 图像的点运算 第4章 图像的几何变换 第5章 图像的正交变换 第...
《Visual C++数字图像处理典型算法及实现》是一本深入探讨使用Microsoft Visual C++进行数字图像处理技术的书籍。该书配套光盘包含了丰富的源代码示例,旨在帮助读者理解和应用各种图像处理算法,从而提升在图像分析...
《数字信号处理题解及电子课件》_MATLAB程序这个压缩包文件包含了胡广书教授的《数字信号处理理论、算法与实现》一书的课后习题解答及相关的MATLAB实现。这本书是数字信号处理领域的经典教材,涵盖了广泛的理论知识...
《精通VC++数字图像处理典型算法及实现》是一本深入探讨如何使用VC++进行数字图像处理的教材。这本书的核心在于其精简实用的算法实现,为学习和实践VC++图像处理技术提供了丰富的案例。标签中提到的关键点包括“VC++...
数字信号处理算法与实现课程项目_Dspmain.zip 数字信号处理算法与实现课程项目_Dspmain.zip 数字信号处理算法与实现课程项目_Dspmain.zip 数字信号处理算法与实现课程项目_Dspmain.zip 数字信号处理算法与实现课程...
遗传算法的JS实现源码(课程设计).zip遗传算法的JS实现源码(课程设计).zip遗传算法的JS实现源码(课程设计).zip遗传算法的JS实现源码(课程设计).zip遗传算法的JS实现源码(课程设计).zip遗传算法的JS实现源码...
算法实现代码:给定表示书的页码n,计算书的全部页码中分别用到多少次数字0,1,2,3,4,5,6,7,8,9