摘自http://blog.sina.com.cn/s/blog_4b687eac0100f0oa.html

21  22  ...
20  7   8   9   10
19  6   1   2   11
18  5   4   3   12
17  16  15  14  13

看清以上数字排列的规律,设 1 点的坐标是 (0,0),x 方向向右为正,y 方向向下为正。例如,7 的坐标为 (-1,-1),2 的坐标为 (0,1),3 的坐标为 (1,1)。编程实现输入任意一点坐标 (x,y),输出所对应的数字。[Finland 某著名通信设备公司 2005 年面试题]

规律是什么?规律真的一看就能看出来,问题就在于如何利用它。

先来个大点的:

43 44 45 46 47 48 49
     42 21 22 23 24 25 26
     41 20 7  8  9  10 27
     40 19 6  1  2  11 28  
     39 18 5  4  3  12 29 
     38 17 16 15 14 13 30
     37 36 35 34 33 32 31

很明显这个队列是顺时针螺旋向外扩展的,我们可以把它看成一层一层往外延伸。第 0 层规定为中间的那个 1,第 1 层为 2 到 9,第 2 层为 10 到 25,……好像看出一点名堂来了?注意到 1、9、25、……不就是平方数吗?而且是连续奇数(1、3、5、……)的平方数。这些数还跟层数相关,推算一下就可以知道第 t 层之内(注意:不包括第t层)一共有 (2t-1)^2 个数——即第0层内有1个数,第1层内有9个数,第2层内有25个数...因而第 t 层会从 [(2t-1)^2] + 1 开始继续往外螺旋。给定坐标 (x,y),如何知道该点处于第几层?so easy,层数 t = max(|x|,|y|),例如:(0,1)在第1层为2,(-1,-1)在第1层为7...

知道了层数,接下来就好办多了,这时我们就知道所求的那点一定在第 t 层这个圈上,顺着往下数就是了。要注意的就是螺旋队列数值增长方向和坐标轴正方向并不一定相同。我们可以分成四种情况——上、下、左、右——或者——东、南、西、北,分别处于四条边上来分析。简单说来就是每一圈数字分为四个区域。

东|右:x == t,队列增长方向和 y 轴一致,正东方向(y = 0)数值为 (2t-1)^2 + t,所以 v = (2t-1)^2 + t + y

南|下:y == t,队列增长方向和 x 轴相反,正南方向(x = 0)数值为 (2t-1)^2 + 3t,所以 v = (2t-1)^2 + 3t - x

西|左:x == -t,队列增长方向和 y 轴相反,正西方向(y = 0)数值为 (2t-1)^2 + 5t,所以 v = (2t-1)^2 + 5t - y

北|上:y == -t,队列增长方向和 x 轴一致,正北方向(x = 0)数值为 (2t-1)^2 + 7t,所以 v = (2t-1)^2 + 7t + x

其实还有一点很重要,不然会有大 bug。其它三条边都还好,但是在东边(右边)那条线上,队列增加不完全符合公式!注意到东北角(右上角)是本层的最后一个数,再往下却是本层的第一个数,那当然不满足东线公式啊。怎么办?好办。反正其它三条都满足不是吗,我们把东线的判断放在最后(其实只需要放在北线之后就可以),这样一来,东北角那点始终会被认为是北线上的点啦~

实现代码如下:

#include<stdio.h>

#define max(a,b) ((a)<(b)?(b):(a))
#define abs(a) ((a)>0?(a):-(a))
int foo(int x,int y)
{
int t=max(abs(x),abs(y));//求出层数t
int u=t + t;
int v=u - 1;
v=v*v+u;//即v = (2t-1)^2 + 2t
if(x==-t)
v+=u+t-y;//v = (2t-1)^2 + 5t - y
else if(y==-t)
v+=3*u+x-t;//v = (2t-1)^2 + 7t + x
else if(y==t)
v+=t-x;//v = (2t-1)^2 + 3t - x
else
v+=y-t;//v = (2t-1)^2 + t + y
return v;

}
void main()

{
int x,y;
for(y=-4;y<=4;y++)
{
for(x=-4;x<=4;x++)
printf("%5d",foo(x,y));
printf("\n");
}
while(scanf("%d%d",&x,&y)==2)
printf("%d\n",foo(x,y));

return 0;

}

c++面试准备之螺旋队列相关推荐

  1. 消息队列面试 - 如何进行消息队列架构设计?

    消息队列面试 - 如何进行消息队列架构设计? 面试题 如果让你写一个消息队列,该如何进行架构设计?说一下你的思路. 面试官心理分析 其实聊到这个问题,一般面试官要考察两块: 你有没有对某一个消息队列做 ...

  2. 消息队列面试 - 如何解决消息队列的延时以及过期失效问题?

    消息队列面试 - 如何解决消息队列的延时以及过期失效问题? 面试题 如何解决消息队列的延时以及过期失效问题?消息队列满了以后该怎么处理?有几百万消息持续积压几小时,说说怎么解决? 面试官心理分析 你看 ...

  3. 消息队列面试 - 为什么使用消息队列,消息队列有什么优点和缺点?

    消息队列面试 - 为什么使用消息队列,消息队列有什么优点和缺点? 面试题 为什么使用消息队列? 消息队列有什么优点和缺点? Kafka.ActiveMQ.RabbitMQ.RocketMQ 都有什么区 ...

  4. 螺旋队列顺时针方向 和逆时针方向的实现

    这个博主找规律的部分写得很好,原样放在下面.最后给出了顺时针和逆时针方向的螺旋队列的实现,可以看出它们的差别如此之小. 和螺旋队列类似,也是找规律的zigzag数组见这个帖子. 螺旋队列的样子如下图: ...

  5. 螺旋矩阵、螺旋队列算法

    问题描述 螺旋矩阵是一个nxn的方阵,其中元素为自然数,但像螺旋方向一样递增.举例如下: 若n = 3,螺旋矩阵为: 1 2 3 8 9 4 7 6 5 若n = 4,螺旋矩阵为: 1 2 3 4 1 ...

  6. 面试官:消息队列这些我必问!

    点击上方"方志朋",选择"设为星标" 回复"666"获取新整理的面试文章 作者:mousycoder segmentfault.com/a/ ...

  7. 算法面试:栈实现队列的方案

    声明:码字不易,转载请注明出处,欢迎文章下方讨论交流. 前言:Java数据结构与算法专题会不定时更新,欢迎各位读者监督.本篇文章介绍一个有趣的问题:用两个栈实现一个队列.这道题来自互联网公司的算法面试 ...

  8. rabbitmq 拉取消息太慢_面试官:消息队列这些我都要问

    作者:mousycoder segmentfault.com/a/1190000021054802 消息队列连环炮 项目里怎么样使用 MQ 的? 为什么要使用消息队列? 消息队列有什么优点和缺点? k ...

  9. mq集群要建传输队列吗_面试官:消息队列这些我必问!

    作者:mousycoder segmentfault.com/a/1190000021054802 消息队列连环炮 项目里怎么样使用 MQ 的? 为什么要使用消息队列? 消息队列有什么优点和缺点? k ...

最新文章

  1. 【Java】 链表的回文结构
  2. 北京内推 | 微软亚洲研究院MSRA STCA招聘多模态算法实习生
  3. iOS开发之Quartz 2D绘图
  4. [react] createElement与cloneElement两者有什么区别?
  5. 蓝桥学院2019算法题2.17
  6. 没有完美,一切只是角度
  7. 网络安全教程下载,呵呵
  8. pycharm 服务器证书错误,pycharm 如何跳出服务器证书不受信任的提示
  9. 提供我现用的Vs配色(灰黑色调)下载,有兴趣的朋友玩玩。
  10. DB2 9 根本(730 检修)认证指南,第 6 局部: 数据并发性(2)
  11. oracle 多实例 端口,Oracle一个实例配置多个listener或多个端口
  12. python下载手机app视频教程_Python实例教学
  13. 小鬼授权系统源码全解密源码 附授权代码
  14. 从物联网到元宇宙 PPT
  15. 如何在团队内做技术分享
  16. 夏令时-前端要知道的知识
  17. 三小时学会css(菜鸟教程精华版)【中】
  18. QT中QSet容器报错: error: C2678: 二进制“==”: 没有找到接受“const Key类型的左操作数的运算符。
  19. USB Network Native Driver for ESXi更新到支持ESXi7.0.1
  20. swiper一行多图踩坑

热门文章

  1. android四个组件的跨进程通信
  2. 通过URL传参数,然后第二个页面需要获取参数
  3. Codeforces Round #337 (Div. 2) C. Harmony Analysis
  4. Cacti监控一台Webserver上多个Tomcatport的实现
  5. 更方便的函数回调——Lambda
  6. Enterprise Library 企业库 V4.1
  7. BizTalk Server 2010新功能介绍(六):BizTalk Mapper (下)
  8. 删除临时表并且插入数据
  9. VS VC 读取 INI文件
  10. 脑功能成像研究之我见-组会讲稿