`

数字绕圈算法 JS 实现

 
阅读更多

这是一道某公司的算法题,我们姑且称之为“数字绕圈算法”。

题目:给定一个数字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('');
}

 

  • 大小: 5 KB
分享到:
评论

相关推荐

    面试题 数字绕圈(含答案)

    这道名为“面试题 数字绕圈(含答案)”的题目是面试中常见的逻辑思维与编程挑战,尤其在IT行业中,这种类型的问题被用来评估应聘者的观察力、问题解决能力和编程技能。通常这类问题会涉及一定的数学规律和编程实现,...

    实现数字签名算法(DSA),Hash算法的实现C语言

    1)利用C\C++语言实现DSA算法。 2)DSA中的Hash函数采用SHA算法。 (1)消息填充:因为我们存储的时候是以字节为单位存储的,所以消息的长度(单位:位)一定是 8 的倍数。而我们填充的时候也一定是 8 位、8 位...

    数字信号处理理论算法与实现

    L变换、DCT及其在图像压缩中的应用)、信号处理中若干典型算法(如抽取与插值、子带分解、调制与解调、反卷积、SVD、独立分量分析及同太民滤波等)、平稳随机信号的基本概念、经典功率谱估计、参数模型功率谱估计、...

    数字信号处理算法c语言实现

    本主题将深入探讨如何使用C语言实现数字信号处理算法,主要包括信号的发生、信号采集以及滤波算法。 首先,我们要了解数字信号的发生。在C语言中,可以使用循环结构和数学函数来生成各种类型的数字信号,如正弦波、...

    数字信号处理——理论、算法与实现的答案

    《数字信号处理——理论、算法与实现》是胡广书教授的一本经典教材,它深入浅出地介绍了数字信号处理的基础知识、核心算法及其在实际中的应用。这本书的答案集为学习者提供了宝贵的参考,帮助他们理解和掌握课程内容...

    Visual C++数字图像处理典型算法及实现(PDF+源码)

    《Visual C++数字图像处理典型算法及实现》一书,主要涵盖了C++在数字图像处理领域的广泛应用和技术。作为一本已绝版的专业书籍,它对于学习和研究C++图像处理技术的人来说,具有很高的参考价值。书中深入浅出地讲解...

    数字信号处理 理论算法与实现 胡广书 第二版 源程序

    《数字信号处理:理论算法与实现》是胡广书教授的经典著作,第二版更是深受广大读者和学习者喜爱。这本书深入浅出地介绍了数字信号处理的基础理论、算法以及其实现方法,是通信工程、电子工程、计算机科学等相关领域...

    数字信号处理 理论 算法与实现.配书光盘.C.Fortran.Matlab.rar

    《数字信号处理:理论、算法与实现》是一本深入探讨数字信号处理领域的经典著作,它涵盖了数字信号处理的基础理论、核心算法以及实际应用。这本书的配套光盘包含了C语言、Fortran语言和Matlab的程序代码,为读者提供...

    Visual+C++数字图像处理典型算法及实现(附光盘)

    Visual+C++数字图像处理典型算法及实现 全书配套光盘

    数字签名算法,c++实现,RSA的算法

    这里的压缩包文件聚焦于RSA算法的C++实现以及数字签名的相关程序。RSA是一种非对称加密算法,由Ron Rivest、Adi Shamir和Leonard Adleman在1977年提出,因其发明者的名字首字母命名。它广泛应用于数字证书、网络通信...

    数字签名 RSA算法 c++

    包涵三个RSA算法,c++是实现,数字签名的合集,三个独自的程序,可以独自编译运行,VC6.0下编译 包涵三个RSA算法,c++是实现,数字签名的合集,三个独自的程序,可以独自编译运行,VC6.0下编译

    数字加网图像处理调频加网抖动算法误差扩散算法C++实现

    本文主要探讨的是一系列C++实现的数字加网算法,具体包括调频加网和抖动算法,如Bayer算法、Halftone算法、Stucki算法、Jarvis算法以及Floyd-Steinberg算法。 1. **Bayer抖动算法**:Bayer算法是最早的色彩滤波阵列...

    精通 Visual C++ 数字图像处理典型算法及实现 第2版 (张宏林)

    《精通Visual C++ 数字图像处理典型算法及实现》 第2版 (张宏林) 扫描PDF版及源码 目录 第1章 Visual C++数字图像编程基础 第2章 图像感知与获取 第3章 图像的点运算 第4章 图像的几何变换 第5章 图像的正交变换 第...

    求是科技《Visual C++数字图像处理典型算法及实现》配套光盘

    《Visual C++数字图像处理典型算法及实现》是一本深入探讨使用Microsoft Visual C++进行数字图像处理技术的书籍。该书配套光盘包含了丰富的源代码示例,旨在帮助读者理解和应用各种图像处理算法,从而提升在图像分析...

    数字信号处理理论、算法与实现_胡广书 课后题部分matlab程序

    《数字信号处理题解及电子课件》_MATLAB程序这个压缩包文件包含了胡广书教授的《数字信号处理理论、算法与实现》一书的课后习题解答及相关的MATLAB实现。这本书是数字信号处理领域的经典教材,涵盖了广泛的理论知识...

    精通VC++数字图像处理典型算法及实现

    《精通VC++数字图像处理典型算法及实现》是一本深入探讨如何使用VC++进行数字图像处理的教材。这本书的核心在于其精简实用的算法实现,为学习和实践VC++图像处理技术提供了丰富的案例。标签中提到的关键点包括“VC++...

    数字信号处理算法与实现课程项目-Dspmain.zip

    数字信号处理算法与实现课程项目_Dspmain.zip 数字信号处理算法与实现课程项目_Dspmain.zip 数字信号处理算法与实现课程项目_Dspmain.zip 数字信号处理算法与实现课程项目_Dspmain.zip 数字信号处理算法与实现课程...

    遗传算法的JS实现源码(课程设计).zip

    遗传算法的JS实现源码(课程设计).zip遗传算法的JS实现源码(课程设计).zip遗传算法的JS实现源码(课程设计).zip遗传算法的JS实现源码(课程设计).zip遗传算法的JS实现源码(课程设计).zip遗传算法的JS实现源码...

    算法实现题:统计数字问题

    算法实现代码:给定表示书的页码n,计算书的全部页码中分别用到多少次数字0,1,2,3,4,5,6,7,8,9

Global site tag (gtag.js) - Google Analytics